Pythonで文字列内の文字の位置を取得するにはどうすればよいですか?
Pythonで文字列内の文字の位置を取得するにはどうすればよいですか?
回答:
そここのため、2つの文字列の方法がある、find()
とindex()
。2つの違いは、検索文字列が見つからない場合にどうなるかです。 find()
戻る-1
とindex()
上げるValueError
。
find()
>>> myString = 'Position of a character'
>>> myString.find('s')
2
>>> myString.find('x')
-1
index()
>>> myString = 'Position of a character'
>>> myString.index('s')
2
>>> myString.index('x')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: substring not found
string.find(s, sub[, start[, end]])
最下位インデックス戻りのサブストリングサブように発見されたサブ完全に含まれているがs[start:end]
。-1
失敗時に戻ります。負の値の開始と終了、および解釈のデフォルトは、スライスの場合と同じです。
そして:
string.index(s, sub[, start[, end]])
同様find()
しかし昇給ValueError
部分文字列が見つからなかった場合。
完全を期すために、文字列内の文字のすべての位置を見つける必要がある場合は、次の操作を実行できます。
s = 'shak#spea#e'
c = '#'
print [pos for pos, char in enumerate(s) if char == c]
戻ります [4, 9]
print( [pos for pos, char in enumerate(s) if char == c])
foo = ( [pos for pos, char in enumerate(s) if char == c])
座標fooをリスト形式にします。私はこれが本当に役立つと思います
>>> s="mystring"
>>> s.index("r")
4
>>> s.find("r")
4
「曲がりくねった」方法
>>> for i,c in enumerate(s):
... if "r"==c: print i
...
4
部分文字列を取得するには、
>>> s="mystring"
>>> s[4:10]
'ring'
str[from:to]
ここでfrom
、to
インデックスは
完了のために、ファイル名で拡張子を確認して確認したい場合は、最後の「。」を見つける必要があります。この場合はrfindを使用します。
path = 'toto.titi.tata..xls'
path.find('.')
4
path.rfind('.')
15
私の場合、完全なファイル名が何であっても機能する次のコードを使用します。
filename_without_extension = complete_name[:complete_name.rfind('.')]
left = q.find("{"); right = q.rfind("}")
。
文字列に重複文字が含まれているとどうなりますか?私との私の経験から、index()
重複に対しては同じインデックスを取得することがわかりました。
例えば:
s = 'abccde'
for c in s:
print('%s, %d' % (c, s.index(c)))
戻ります:
a, 0
b, 1
c, 2
c, 2
d, 4
その場合、あなたはそのようなことをすることができます:
for i, character in enumerate(my_string):
# i is the position of the character in the string
enumerate
そういうことにはいいです
string.find(character)
string.index(character)
おそらく、2つの違いが何であるかを見つけるために、ドキュメントを参照したいと思うでしょう。
文字は文字列内に複数回現れることがあります。たとえば、文字列ではsentence
、位置はe
isです1, 4, 7
(インデックス作成は通常ゼロから始まるため)。しかし、私が見つけたのは両方の関数でfind()
ありindex()
、文字の最初の位置を返します。だから、これはこれを行うことで解決できます:
def charposition(string, char):
pos = [] #list to store positions for each 'char' in 'string'
for n in range(len(string)):
if string[n] == char:
pos.append(n)
return pos
s = "sentence"
print(charposition(s, 'e'))
#Output: [1, 4, 7]
more_itertools.locate
は、条件を満たすアイテムのすべてのインデックスを検索するサードパーティのツールです。
ここでは、文字のすべてのインデックスの場所を検索します"i"
。
import more_itertools as mit
s = "supercalifragilisticexpialidocious"
list(mit.locate(s, lambda x: x == "i"))
# [8, 13, 15, 18, 23, 26, 30]