![](/img/trans.png)
[英]What's the most Pythonic way to remove a number from start of a string?
[英]What is the most pythonic way to remove characters from a string and create substrings?
假设我们有这个字符串: SIC0575(1, 2)
SIC0575
长度 = 7,但它可以动态变化,所以我们假设长度 = N
(1, 2)
假设 (0~9, 0~9)
我想从这个字符串创建子字符串。
期望的结果:
val1 = SIC0575
val2 = 1
val3 = 2
我不熟悉 Python,我想知道哪种方式是最优雅的/pythonic 方式来实现这一点。 有没有内置的 function 可以做到这一点?
我尝试过的(它有效,但一点也不优雅):
data = "SIC0575(1, 2)"
aux = data.split("(")
val1 = aux[0]
aux2 = aux[1].split(",")
val2 = aux2[0]
val3 = aux2[1][:-1]
正则表达式是你的朋友:
import re
s = "SIC0575(1, 2)"
val1, val2, val3 = re.fullmatch(r"(.*?)\((\d), (\d)\)", s).groups()
对于您的用例,我将 go 与index
获取左括号(
的index
,并取第一个切片为aux
,并使用ast
为val1
, val2
import ast
data = "SIC0575(1, 2)"
index = data.find('(')
aux = data[:index]
val1, val2 = ast.literal_eval(data[index:])
OUTPUT :
print(aux, v1, v2)
SIC0575 1 2
我会 go 如下所示。
import re
stringEx = [_.replace(' ','') for _ in re.split('\)|\(|,',"SIC0575(1, 2)")[:-1]]
var1,var2,var3 = string[0],int(stringEx[1]),int(stringEx[2])
出去
val1 = SIC0575
val2 = 1
val3 = 2
您可以使用正则表达式来匹配字符串。
import re
data = "SIC0575(1, 2)"
pattern = re.compile(r'(.*)\(([0-9]), ([0-9])\)')
val1, val2, val3 = pattern.match(data).groups()
print(val1, val2, val3)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.