这里对 Python 非常陌生。
我有一个 python 脚本,它评估数据契约的每一行,并根据一组标准提取某些值。我需要修改脚本,现在还可以从 DataMember 行中提取名称值。但是,我在使新的 ExtractDataMemberName 函数正常工作时遇到问题。
首先,我有一个函数,它使用此 for
语句迭代文件的每一行:
for line in file:
if IsDataMemberAttribute(line):
name = ExtractDataMemberName(line)
elif ...
在 ExtractDataMemberName(line)
函数中,我需要从字符串返回 Name
值,如下面所示的示例输入行。请注意,DataMember 行中属性的数量和顺序可能会有所不同。
示例输入:
"[DataMember(Name = "version", EmitDefaultValue = false, Order = 5)]"
预期输出:
version
我尝试了多种方法,包括尝试 lstrip [DataMember("
and rstrip )]
,然后尝试将生成的字符串拆分为字典,以便我可以找到 Name 值,但我无法让它工作。
任何人都可以推荐从这样的字符串中提取名称值的最佳方法吗?
使用 split 有点难看:
s = '[DataMember(Name = "version", EmitDefaultValue = false, Order = 5)]'
print(s.split("Name =")[1].split(",")[0].strip()[1:-1])
version
或者使用re :
import re
print(re.findall("Name\s+=\s+\"(.*?)\",",s)[0])
version
我是一名优秀的程序员,十分优秀!