문자열을 문자 배열로 나누는 것에 대한 답변을 웹에서 살펴 보았지만 간단한 방법을 찾을 수없는 것 같습니다.
str.split(//)
루비처럼 작동하지 않는 것 같습니다. 루핑 없이이 작업을 수행하는 간단한 방법이 있습니까?
문자열을 문자 배열로 나누는 것에 대한 답변을 웹에서 살펴 보았지만 간단한 방법을 찾을 수없는 것 같습니다.
str.split(//)
루비처럼 작동하지 않는 것 같습니다. 루핑 없이이 작업을 수행하는 간단한 방법이 있습니까?
답변:
cast_method = lambda x: [x]
list () 없이이 간단한 방법으로 수행 할 수도 있습니다.
>>> [c for c in "foobar"]
['f', 'o', 'o', 'b', 'a', 'r']
for
것이며 설명 할 것이 많지 않습니다. 데이터 구조 , 특히 목록 이해 에 대한 파이썬 튜토리얼을 읽어야한다고 생각합니다 .
list(map(lambda c: c, iter("foobar")))
가 있지만 더 읽기 쉽고 의미가 있습니다.
한 번에 한 문자 씩 문자열을 처리하려는 경우. 다양한 옵션이 있습니다.
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 루프 사용하기 :
for c in uhello:
print(c)
산출:
H
e
l
l
o
W
o
r
l
d
이 작업을 수행하는 또 다른 두 가지 방법을 탐색했습니다. 누군가에게 도움이 될 수 있습니다.
첫 번째는 쉽다 :
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', '', '']
더 많은 방법 은 파이썬 문서 를 참조하십시오
이 작업은 문자열의 문자를 반복하여 목록으로 수집하는 것으로 요약됩니다. 가장 순진한 솔루션은 다음과 같습니다.
result = []
for character in string:
result.append(character)
물론, 그것은 단지 단축 될 수 있습니다
result = [character for character in string]
그러나 여전히 똑같은 일을하는 더 짧은 솔루션이 있습니다.
list
생성자는 iterable (반복자, 목록, 튜플, 문자열 등)을 목록 으로 변환하는 데 사용할 수 있습니다 .
>>> list('abc')
['a', 'b', 'c']
가장 큰 장점은 Python 2와 Python 3에서 모두 동일하게 작동한다는 것입니다.
또한 Python 3.5부터 (굉장한 PEP 448 덕분에 ) 빈 목록 리터럴로 압축을 풀면 모든 iterable에서 목록을 작성할 수 있습니다.
>>> [*'abc']
['a', 'b', 'c']
이것은 더 깔끔하며 어떤 경우에는 전화하는 것보다 더 효율적입니다 list
생성자를 직접 입니다.
Python 3에서는 목록을 반환 하지 않기map
때문에 기반 접근 방식 을 사용 map
하지 않는 것이 좋습니다 . Python 3에서 필터, 맵 및 축소 사용 방법을 참조하십시오 .
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']
camelcase = ''.join([text[i].upper() if i % 2 else text[i].lower() for i in range(len(text))])
>>> for i in range(len(a)):
... print a[i]
...
여기서 a는 분리하려는 문자열입니다. "a [i]"값은 문자열을 목록에 추가 할 수있는 문자열의 개별 문자입니다.
for c in a: print c
더 직접적입니다