文字列を文字の配列に分割する答えをウェブで探してみましたが、簡単な方法を見つけることができないようです
str.split(//)
Rubyのように動作しないようです。ループせずにこれを行う簡単な方法はありますか?
文字列を文字の配列に分割する答えをウェブで探してみましたが、簡単な方法を見つけることができないようです
str.split(//)
Rubyのように動作しないようです。ループせずにこれを行う簡単な方法はありますか?
回答:
>>> s = "foobar"
>>> list(s)
['f', 'o', 'o', 'b', 'a', 'r']
リストが必要です
cast_method = lambda x: [x]
あなたは文字列を受け取り、それをlist()に渡します
s = "mystring"
l = list(s)
print l
また、list()を使用せずに、この非常に単純な方法で行うこともできます。
>>> [c for c in "foobar"]
['f', 'o', 'o', 'b', 'a', 'r']
for
であり、説明することはあまりありません。データ構造に関するpythonチュートリアル、特にリスト内包を読むべきだと思います。
list(map(lambda c: c, iter("foobar")))
しますが、より読みやすく、意味があります。
文字列を一度に1文字ずつ処理する場合。さまざまなオプションがあります。
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
このタスクを達成するための別の2つの方法を検討しました。それは誰かのために役立つかもしれません。
最初のものは簡単です:
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
コンストラクタを直接呼び出すよりも効率的です。
はPython 3ではリストを返さないmap
ため、ベースのアプローチを使用map
しないことをお勧めします。Python3でフィルター、マップ、およびリデュースを使用する方法を参照してください。
split()
組み込み関数は、特定の条件に基づいて値を分離するだけですが、単一の単語では、条件を満たすことができません。したがって、それはの助けを借りて解決できますlist()
。内部的に配列を呼び出し、配列に基づいて値を格納します。
仮に
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']
それらを解凍します。
word = "Paralelepipedo"
print([*word])
文字列への読み取り専用アクセスを希望する場合は、配列表記を直接使用できます。
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
まあ、私がリストバージョンを好きなように、これは私が見つけたもう1つのより冗長な方法です(しかし、それはクールなので、私はそれを争いに追加したいと思いました):
>>> 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
はるかに直接的です