1

我试图从下面的字符串中提取子字符串

   package: name='com.example.tracker' versionCode='1' versionName='1.0'

作为字符串 1:versionCode='1' 和作为字符串 2:versionName='1.0'

我使用 str.find('versionCode) 返回版本代码中“v”的索引,并使用字符串长度访问“1”。但是有时版本代码可能是两位数,因此我无法修复该数字的位置。有没有办法做到这一点?

如果字符串是

    package: name='com.example.tracker' versionCode='12' versionName='12.0'

我需要提取 12 和 12.0。我的实现可以支持个位数,但数字会有所不同。

 if line.find('versionCode') != -1:
            x = line.find('versionCode') 
            versionCode = line[x+13:x+15] 
4

3 回答 3

1

您需要使用正则表达式来执行此操作。

在下面的每一行中,我们使用该模式(.*?)在引号内执行非贪婪搜索以提取字符串,然后拉取group(1)而不是group(0)在返回的对象上,因为0返回整个输入字符串的完全匹配,并1给出第一个正则表达式捕获组。

import re

packageDetails = "package: name='com.example.tracker' versionCode='1' versionName='1.0'"
name = re.search("name='(.*?)'", packageDetails).group(1)
versionCode = re.search("versionCode='(.*?)'", packageDetails).group(1)
versionName = re.search("versionName='(.*?)'", packageDetails).group(1)

print "package name is :", name
print "version code is :", versionCode
print "version name is :", versionName 

这输出:

package name is : com.example.tracker
version code is : 1
version name is : 1.0
于 2013-09-17T23:58:42.377 回答
1

您可以使用内置方法操作字符串以获得所需的值:

packageDetails = "package: name='com.example.tracker' versionCode='1' versionName='1.0'"
details = packageDetails
params = ['name=', 'versionCode=', 'versionName=']
params.reverse()
values = []
for p in params:
    details, v = details.split(p)
    values.append(v.strip().strip("'"))
values.reverse()
于 2013-09-18T01:11:47.483 回答
0

或者你可以建立一个字典:

>>> details = { x.split('=')[0] : x.split('=')[1].strip("'") for x in a.split()[1:] }
>>> details
{
  "name" : "com.example.tracker",
  "versionCode" : "1",
  "versionName" : "1.0"
}
>>> details['name']
"com.example.tracker"
>>> details['versionCode'] == '1'
true

或者,如果您不关心剥离“'”

>>> dict(x.split('=') for x in a.split()[1:])
{
  "name" : "'com.example.tracker'",
  "versionCode" : "'1'",
  "versionName" : "'1.0'"
}
于 2013-09-18T00:48:23.500 回答