Ответы:
Как отметил Йоханнес,
for c in "string":
#do something with c
Вы можете перебрать почти все в Python, используя for loop
конструкцию,
например, open("file.txt")
возвращает объект файла (и открывает файл), повторяя его итерируя по строкам в этом файле
with open(filename) as f:
for line in f:
# do something with line
Если это похоже на магию, ну, в общем-то, так и есть, но идея, стоящая за этим, очень проста.
Существует простой протокол итератора, который можно применить к любому объекту, чтобы for
цикл работал на нем.
Просто реализуйте итератор, который определяет next()
метод, и реализуйте __iter__
метод в классе, чтобы сделать его итеративным. ( __iter__
конечно, должен возвращать объект итератора, то есть объект, который определяет next()
)
Если вам нужен доступ к индексу во время итерации по строке, используйте enumerate()
:
>>> for i, c in enumerate('test'):
... print i, c
...
0 t
1 e
2 s
3 t
1 t
, 2 e
, 3 s
, 4 t
используйте параметр «Пуск»:for i, c in enumerate('test', start=1)
Еще проще:
for c in "test":
print c
for c in "test": print (c)
почему?
Просто чтобы дать более полный ответ, способ итерации по строке в C может применяться в Python, если вы действительно хотите вбить квадратный колышек в круглое отверстие.
i = 0
while i < len(str):
print str[i]
i += 1
Но опять же, зачем это делать, когда строки по своей природе итеративны?
for i in str:
print i
for i in range(len(...))
это зло В python 2.x range()
создается список, поэтому для очень большой длины вы можете выделить очень большой блок памяти. По крайней мере, использовать xrange()
в этих случаях. Кроме того, повторное индексирование одной и той же строки намного медленнее, чем итерация непосредственно по строке. Если вам нужен индекс, используйте enumerate()
.
Ну, вы также можете сделать что-то интересное, как это и сделать свою работу с помощью цикла for
#suppose you have variable name
name = "Mr.Suryaa"
for index in range ( len ( name ) ):
print ( name[index] ) #just like c and c++
Ответ
Г-н . Сурия
Однако, так как range () создает список значений, который является последовательностью, таким образом, вы можете напрямую использовать имя
for e in name:
print(e)
Это также дает тот же результат, а также выглядит лучше и работает с любой последовательностью, такой как список, кортеж и словарь.
Мы использовали буксировку встроенных функций (BIFs в Python Community)
1) range () - range () BIF используется для создания индексов. Пример
for i in range ( 5 ) :
can produce 0 , 1 , 2 , 3 , 4
2) len () - len () BIF используется для определения длины заданной строки
Если вы хотите использовать более функциональный подход к итерации по строке (возможно, для ее преобразования), вы можете разбить строку на символы, применить функцию к каждому из них, а затем соединить полученный список символов обратно в строку.
Строка по своей сути является списком символов, поэтому «map» будет перебирать строку - как второй аргумент - применяя функцию - первый аргумент - к каждому.
Например, здесь я использую простой лямбда-подход, поскольку все, что я хочу сделать, - это тривиальное изменение символа: здесь, чтобы увеличить значение каждого символа:
>>> ''.join(map(lambda x: chr(ord(x)+1), "HAL"))
'IBM'
или в целом:
>>> ''.join(map(my_function, my_string))
где my_function принимает значение char и возвращает значение char.
Здесь используют несколько ответов range
. xrange
обычно лучше, поскольку он возвращает генератор, а не полностью созданный список. Там, где память и / или итерации широко варьируемой длины могут быть проблемой, xrange
лучше.
Если вы когда-либо сталкивались с ситуацией, когда вам это нужно get the next char of the word using __next__()
, не забудьте создать string_iterator
и выполнить итерацию, а неoriginal string (it does not have the __next__() method)
В этом примере, когда я нахожу символ =, [
я продолжаю искать следующее слово, пока не нахожу ]
, поэтому мне нужно использовать __next__
здесь цикл по строке не поможет
myString = "'string' 4 '['RP0', 'LC0']' '[3, 4]' '[3, '4']'"
processedInput = ""
word_iterator = myString.__iter__()
for idx, char in enumerate(word_iterator):
if char == "'":
continue
processedInput+=char
if char == '[':
next_char=word_iterator.__next__()
while(next_char != "]"):
processedInput+=next_char
next_char=word_iterator.__next__()
else:
processedInput+=next_char