Python: как распечатать диапазон az?


110

1. Распечатайте: abcdefghijklmn.

2. Каждую секунду в: acegikm

3. Добавьте в индекс URL-адресов {hello.com/, hej.com/, ..., hallo.com/}: hello.com/a hej.com/b ... hallo.com/n


6
Странно, что на вопрос «новичка» можно получить множество ответов. Тот факт, что я умею печатать, не означает, что я умею "питон", мне очень нравятся ответы гниблера, а не беспорядочные вещи. Спасибо всем за ответы и - простите, особая благодарность gnibbler.
HHH

2
Это не огромное разнообразие ответов. Это две разновидности. Один использует, rangeа chr()другой - готовые списки string, о которых многие даже не догадываются.
Леннарт Регебро

Ответы:


191
>>> import string
>>> string.ascii_lowercase[:14]
'abcdefghijklmn'
>>> string.ascii_lowercase[:14:2]
'acegikm'

Чтобы сделать URL-адреса, вы можете использовать что-то вроде этого

[i + j for i, j in zip(list_of_urls, string.ascii_lowercase[:14])]

1
Я считаю, что string.ascii_lowercase уже работал в python 2.x, поэтому для уверенности всегда используйте ascii_lowercase.
johk95

1
@ johk95, на самом деле str.lowercaseзависит от локали, поэтому изначально был не лучшим выбором. Я заменил его в своем ответе
Джон Ла Рой

Привет, мог бы я сказать, доступно ли это только на английском языке? не могу я получить то же самое и для других языков? Спасибо и наилучшие пожелания
Майкл Шротер

48

Предполагая, что это домашнее задание ;-) - не нужно вызывать библиотеки и т.д. - вероятно, вы ожидаете, что вы будете использовать range () с chr / ord, например:

for i in range(ord('a'), ord('n')+1):
    print chr(i),

В остальном просто поиграйте немного с range ()




12

Получите список с желаемыми значениями

small_letters = map(chr, range(ord('a'), ord('z')+1))
big_letters = map(chr, range(ord('A'), ord('Z')+1))
digits = map(chr, range(ord('0'), ord('9')+1))

или

import string
string.letters
string.uppercase
string.digits

В этом решении используется таблица ASCII . ordполучает значение ascii от символа и chrнаоборот.

Применяйте то, что вы знаете о списках

>>> small_letters = map(chr, range(ord('a'), ord('z')+1))

>>> an = small_letters[0:(ord('n')-ord('a')+1)]
>>> print(" ".join(an))
a b c d e f g h i j k l m n

>>> print(" ".join(small_letters[0::2]))
a c e g i k m o q s u w y

>>> s = small_letters[0:(ord('n')-ord('a')+1):2]
>>> print(" ".join(s))
a c e g i k m

>>> urls = ["hello.com/", "hej.com/", "hallo.com/"]
>>> print([x + y for x, y in zip(urls, an)])
['hello.com/a', 'hej.com/b', 'hallo.com/c']

Похоже , string.letters была удалена в Python 3 и только string.ascii_letters, не точно так же , доступен
jonespm

8
import string
print list(string.ascii_lowercase)
# ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

1
Чтобы сделать это кортежем (который является неизменным) в Python 3:tuple(string.ascii_lowercase)
Алекс Уиллисон,

6
import string
print list(string.ascii_lowercase)
# ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

и

for c in list(string.ascii_lowercase)[:5]:
    ...operation with the first 5 characters

4
myList = [chr(chNum) for chNum in list(range(ord('a'),ord('z')+1))]
print(myList)

Вывод

['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

Добро пожаловать в StackOverflow. Постарайтесь более четко объяснить, почему это исчерпывающий ответ на вопрос.
Jeroen

Спасибо. Мне нравится, как вы это строите.
hmacias

2
#1)
print " ".join(map(chr, range(ord('a'),ord('n')+1)))

#2)
print " ".join(map(chr, range(ord('a'),ord('n')+1,2)))

#3)
urls = ["hello.com/", "hej.com/", "hallo.com/"]
an = map(chr, range(ord('a'),ord('n')+1))
print [ x + y for x,y in zip(urls, an)]

2

Ответ на этот вопрос прост, просто составьте список под названием ABC следующим образом:

ABC = ['abcdefghijklmnopqrstuvwxyz']

И всякий раз, когда вам нужно обратиться к нему, просто сделайте:

print ABC[0:9] #prints abcdefghij
print ABC       #prints abcdefghijklmnopqrstuvwxyz
for x in range(0,25):
    if x % 2 == 0:
        print ABC[x] #prints acegikmoqsuwy (all odd numbered letters)

Также попробуйте это, чтобы сломать устройство ur: D

##Try this and call it AlphabetSoup.py:

ABC = ['abcdefghijklmnopqrstuvwxyz']


try:
    while True:
        for a in ABC:
            for b in ABC:
                for c in ABC:
                    for d in ABC:
                        for e in ABC:
                            for f in ABC:
                                print a, b, c, d, e, f, '    ',
except KeyboardInterrupt:
    pass


1

Это ваш второй вопрос: string.lowercase[ord('a')-97:ord('n')-97:2]потому что 97==ord('a')- если вы хотите немного научиться, вы должны сами решить остальное ;-)




0
list(string.ascii_lowercase)

['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

0

Другой способ сделать это

  import string
  pass

  aalist = list(string.ascii_lowercase)
  aaurls = ['alpha.com','bravo.com','chrly.com','delta.com',]
  iilen  =  aaurls.__len__()
  pass

  ans01 = "".join( (aalist[0:14]) )
  ans02 = "".join( (aalist[0:14:2]) )
  ans03 = "".join( "{vurl}/{vl}\n".format(vl=vjj[1],vurl=aaurls[vjj[0] % iilen]) for vjj in enumerate(aalist[0:14]) )
  pass

  print(ans01)
  print(ans02)
  print(ans03)
  pass

Результат

abcdefghijklmn
acegikm
alpha.com/a
bravo.com/b
chrly.com/c
delta.com/d
alpha.com/e
bravo.com/f
chrly.com/g
delta.com/h
alpha.com/i
bravo.com/j
chrly.com/k
delta.com/l
alpha.com/m
bravo.com/n

Чем это отличается от других ответов

  • перебирать произвольное количество базовых URL
  • прокрутите URL-адреса и не останавливайтесь, пока у нас не закончатся буквы
  • использовать enumerateвместе с пониманием списка и str.format
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.