gpt4 book ai didi

Python:如何在使用 str.lower 时避免字符串中的特定单词小写

转载 作者:太空宇宙 更新时间:2023-11-04 10:53:41 26 4
gpt4 key购买 nike

我是 python 新手

我有一个字符串列表如下

mylist=["$(ProjectDir)Dir1\Dest1","$(OutDir)Dir2\Dest2","$(IntDir)Dir2\Dest2"]

我想将每个列表项值小写如下

mylist=["$(ProjectDir)dir1\dest1","$(OutDir)dir2\dest2","$(IntDir)dir3\dest3"]

即我想防止$(ProjectDir),$(OutDir),$(IntDir)小写

最佳答案

这个想法很简单。您使用描述不需要转换的部分的正则表达式拆分字符串,然后仅转换其偶数部分,然后将它们连接回去。

>>> import re
>>> mylist=["$(ProjectDir)Dir1\Dest1","$(OutDir)Dir2\Dest2","$(IntDir)Dir2\Dest2"]
>>> print ["".join([s if i%2 else s.lower() for (i,s) in enumerate(re.split('(\$\([^)]*\))', x))]) for x in mylist]
['$(ProjectDir)dir1\\dest1', '$(OutDir)dir2\\dest2', '$(IntDir)dir2\\dest2']

这里最主要的是:

[ "".join([
s if i%2 else s.lower()
for (i,s) in enumerate(re.split('(\$\([^)]*\))', x))])
for x in mylist ]

你遍历列表 mylist并且对于每个 x 产生它的修改版本:

[ ... for x in mylist ]

您使用此操作转换每个 x:

"".join([
s if i%2 else s.lower()
for (i,s) in enumerate(re.split('(\$\([^)]*\))', x))]

这意味着:将字符串拆分为必须转换(偶数)和不能转换(奇数)的部分。

例如:

>>> re.split('(\$\([^)]*\))', x)
['', '$(ProjectDir)', 'Dir1\\Dest1']

然后枚举它们并转换所有偶数部分:

>>> print list(enumerate(re.split('(\$\([^)]*\))', x)))
[(0, ''), (1, '$(ProjectDir)'), (2, 'Dir1\\Dest1')]

如果一个部分是偶数或奇数,你使用这个 if 检查:

 s if i%2 else s.lower()

关于Python:如何在使用 str.lower 时避免字符串中的特定单词小写,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11756376/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com