Как разбить строку на массив символов?

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

str.split(//), похоже, не работает, как Ruby. Есть ли простой способ сделать это без цикла?

Ответ 1

>>> s = "foobar"
>>> list(s)
['f', 'o', 'o', 'b', 'a', 'r']

Вам нужно list

Ответ 2

Вы берете строку и передаете ее в список()

s = "mystring"
l = list(s)
print l

Ответ 3

Вы также можете сделать это очень простым способом без списка():

>>> [c for c in "foobar"]
['f', 'o', 'o', 'b', 'a', 'r']

Ответ 4

Я изучил еще два пути для выполнения этой задачи. Это может быть полезно для кого-то.

Первый легко:

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 для получения дополнительных методов

Ответ 5

Задача сводится к тому, чтобы перебирать символы строки и собирать их в список. Самое наивное решение будет выглядеть так

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.

Ответ 6

Если вы хотите обрабатывать вашу строку по одному символу за раз. у вас есть разные варианты.

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']

Ответ 7

просто:

s = 'My'    
print(list(s))

Ответ 8

Предположим, что существует имя строки txt.

'''Python 2.7'''
txt = 'India'
arr = list(txt)
print arr

Ответ 9

Встроенная функция 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']

Ответ 10

Если вы хотите читать только доступ к строке, вы можете напрямую использовать запись массива.

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

Ответ 11

Хорошо, так как мне нравится версия списка (ов), вот еще один более подробный способ, который я нашел (но это круто, поэтому я думал, что добавлю его в бой):

>>> 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']

Ответ 12

from itertools import chain

string = 'your string'
chain(string)

похож на list(string) но возвращает генератор, который лениво вычисляется в точке использования, поэтому эффективно использует память.

Ответ 13

>>> for i in range(len(a)):
...     print a[i]
... 

где a - строка, которую вы хотите отделить. Значения "a [i]" являются индивидуальным символом строки, которую они могли бы добавить в список.

Ответ 14

Мне просто нужен массив символов:

arr = list(str)

Если вы хотите разделить строку на определенную строку:

# str = "temp//temps" will will be ['temp', 'temps']
arr = str.split("//")