Я попытался посмотреть в Интернете ответы на разделение строки на массив символов, но я не могу найти простой метод
str.split(//)
, похоже, не работает, как Ruby. Есть ли простой способ сделать это без цикла?
Я попытался посмотреть в Интернете ответы на разделение строки на массив символов, но я не могу найти простой метод
str.split(//)
, похоже, не работает, как Ruby. Есть ли простой способ сделать это без цикла?
>>> s = "foobar"
>>> list(s)
['f', 'o', 'o', 'b', 'a', 'r']
Вам нужно list
Вы берете строку и передаете ее в список()
s = "mystring"
l = list(s)
print l
Вы также можете сделать это очень простым способом без списка():
>>> [c for c in "foobar"]
['f', 'o', 'o', 'b', 'a', 'r']
Я изучил еще два пути для выполнения этой задачи. Это может быть полезно для кого-то.
Первый легко:
In [25]: a = []
In [26]: s = 'foobar'
In [27]: a += s
In [28]: a
Out[28]: ['f', 'o', 'o', 'b', 'a', 'r']
И второй использует map
и lambda
функцию. Это может быть уместно для более сложных задач:
In [36]: s = 'foobar12'
In [37]: a = map(lambda c: c, s)
In [38]: a
Out[38]: ['f', 'o', 'o', 'b', 'a', 'r', '1', '2']
Например
# isdigit, isspace or another facilities such as regexp may be used
In [40]: a = map(lambda c: c if c.isalpha() else '', s)
In [41]: a
Out[41]: ['f', 'o', 'o', 'b', 'a', 'r', '', '']
Смотрите документы python для получения дополнительных методов
Задача сводится к тому, чтобы перебирать символы строки и собирать их в список. Самое наивное решение будет выглядеть так
result = []
for character in string:
result.append(character)
Конечно, его можно сократить до
result = [character for character in string]
но есть более короткие решения, которые делают то же самое.
Конструктор list
может использоваться для преобразования любых итераций (итераторов, списков, кортежей, строк и т.д.) в список.
>>> list('abc')
['a', 'b', 'c']
Большой плюс в том, что он работает одинаково как в Python 2, так и в Python 3.
Кроме того, начиная с Python 3.5 (благодаря великолепному PEP 448) теперь можно построить список из любого итерируемого, распаковав его в пустой литерал списка:
>>> [*'abc']
['a', 'b', 'c']
Это аккуратнее, а в некоторых случаях более эффективно, чем вызов конструктора list
напрямую.
Я бы не советовал использовать подходы map
-based, потому что map
не возвращает список в Python 3. См. Как использовать фильтр, карту и сокращение в Python 3.
Если вы хотите обрабатывать вашу строку по одному символу за раз. у вас есть разные варианты.
uhello = u'Hello\u0020World'
Использование списка понимания:
print([x for x in uhello])
Выход:
['H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd']
Используя карту:
print(list(map(lambda c2: c2, uhello)))
Выход:
['H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd']
Вызов Встроенная функция списка:
print(list(uhello))
Выход:
['H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd']
Использование для цикла:
for c in uhello:
print(c)
Выход:
['H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd']
просто:
s = 'My'
print(list(s))
Предположим, что существует имя строки txt.
'''Python 2.7'''
txt = 'India'
arr = list(txt)
print arr
Встроенная функция split()
будет отделять значение только на основе определенного условия, но в одном слове оно не может выполнить условие. Таким образом, это можно решить с помощью list()
. Он внутренне вызывает Array и будет хранить значение на основе массива.
Предположим,
a = "bottle"
a.split() // will only return the word but not split the every single char.
a = "bottle"
list(a) // will separate ['b','o','t','t','l','e']
Если вы хотите читать только доступ к строке, вы можете напрямую использовать запись массива.
Python 2.7.6 (default, Mar 22 2014, 22:59:38)
[GCC 4.8.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> t = 'my string'
>>> t[1]
'y'
Может быть полезно для тестирования без использования регулярного выражения. Строка содержит конечную новую строку?
>>> t[-1] == '\n'
False
>>> t = 'my string\n'
>>> t[-1] == '\n'
True
Хорошо, так как мне нравится версия списка (ов), вот еще один более подробный способ, который я нашел (но это круто, поэтому я думал, что добавлю его в бой):
>>> text = "My hovercraft is full of eels"
>>> [text[i] for i in range(len(text))]
['M', 'y', ' ', 'h', 'o', 'v', 'e', 'r', 'c', 'r', 'a', 'f', 't', ' ', 'i', 's', ' ', 'f', 'u', 'l', 'l', ' ', 'o', 'f', ' ', 'e', 'e', 'l', 's']
from itertools import chain
string = 'your string'
chain(string)
похож на list(string)
но возвращает генератор, который лениво вычисляется в точке использования, поэтому эффективно использует память.
>>> for i in range(len(a)):
... print a[i]
...
где a - строка, которую вы хотите отделить. Значения "a [i]" являются индивидуальным символом строки, которую они могли бы добавить в список.
Мне просто нужен массив символов:
arr = list(str)
Если вы хотите разделить строку на определенную строку:
# str = "temp//temps" will will be ['temp', 'temps']
arr = str.split("//")