如何在Python中获取字符串中字符的位置?
当前回答
为了完整起见,如果你需要找到字符串中某个字符的所有位置,你可以这样做:
s = 'shak#spea#e'
c = '#'
print([pos for pos, char in enumerate(s) if char == c])
这将打印:[4,9]
其他回答
使用numpy快速访问所有索引的解决方案:
string_array = np.array(list(my_string))
char_indexes = np.where(string_array == 'C')
只是为了完成,在这种情况下,我想在一个文件名中找到扩展名,以便检查它,我需要找到最后一个'。,在这种情况下使用rfind:
path = 'toto.titi.tata..xls'
path.find('.')
4
path.rfind('.')
15
在我的情况下,我使用以下,无论完整的文件名是什么工作:
filename_without_extension = complete_name[:complete_name.rfind('.')]
当字符串包含重复字符时会发生什么? 从我使用index()的经验来看,对于duplicate,你会得到相同的索引。
例如:
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
我发现的大多数方法都是指查找字符串中的第一个子字符串。要找到所有的子字符串,您需要处理。
例如:
定义字符串
vars = 'iloveyoutosimidaandilikeyou'
定义子字符串
key = 'you'
定义一个函数,该函数可以找到字符串中所有子字符串的位置
def find_all_loc(vars, key):
pos = []
start = 0
end = len(vars)
while True:
loc = vars.find(key, start, end)
if loc is -1:
break
else:
pos.append(loc)
start = loc + len(key)
return pos
pos = find_all_loc(vars, key)
print(pos)
[5, 24]
有两个字符串方法,find()和index()。两者之间的区别在于当没有找到搜索字符串时会发生什么。find()返回-1,index()引发ValueError。
使用find ()
>>> myString = 'Position of a character'
>>> myString.find('s')
2
>>> myString.find('x')
-1
使用指数()
>>> 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
来自Python手册
字符串。Find (s, sub[, start[, end]]) 返回s中子字符串sub所在位置的最低索引,使得sub完全包含在s[start:end]中。失败时返回-1。负值的开始和结束以及解释的默认值与切片相同。
And:
字符串。索引(s, sub[, start[, end]]) 类似于find(),但在未找到子字符串时引发ValueError。
推荐文章
- 证书验证失败:无法获得本地颁发者证书
- 当使用pip3安装包时,“Python中的ssl模块不可用”
- 无法切换Python与pyenv
- Python if not == vs if !=
- 如何从scikit-learn决策树中提取决策规则?
- 为什么在Mac OS X v10.9 (Mavericks)的终端中apt-get功能不起作用?
- 将旋转的xtick标签与各自的xtick对齐
- Printf与std::字符串?
- 为什么元组可以包含可变项?
- 如何合并字典的字典?
- 如何创建类属性?
- 不区分大小写的“in”
- 在Python中获取迭代器中的元素个数
- 解析日期字符串并更改格式
- 使用try和。Python中的if