我的python字符串在末尾用\ n换行符分隔:
mystring = "owner: uid=rocdsc,ou=People,dc=fcd,dc=test,dc=com
member: uid=absylor12,ou=people,dc=fcd,dc=test,dc=com
member: uid=amslsmith,ou=people,dc=fcd,dc=test,dc=com
member: uid=amis,ou=people,dc=fcd,dc=test,dc=com
member: uid=null,ou=people,dc=fcd,dc=test,dc=com""
是否有更好的方法来生成uid数组,如下所示:
[rocdsc, absylor12, amslsmith, amis]
没有
空
在数组列表中。
我试过了:
uids= [name.strip() for name in mystring .split("\n")]
if len(uids)>0:
for index in range(len(uids))
#print 'Current UIDs:', uids[index].split(":")
uids[0] = uids[0].split("=")[1].strip()
print uids
答案 0 :(得分:1)
如果您还没有尝试过正则表达式:
import re
r = re.compile(r'uid=(\w+)')
r.findall(mystring)
如果要删除空值,可以filter(lambda x: x != 'null', r.findall(mystring))
(再重复一次)
这个正则表达式有效,但也会删除以单词null
开头的所有uidre.compile(r'uid=((?!null)\w+)').findall(mystring)
答案 1 :(得分:1)
#!python2
import re
mystring = "owner: uid=rocdsc,ou=People,dc=fcd,dc=test,dc=com, member: uid=absylor12,ou=people,dc=fcd,dc=test,dc=com, member: uid=amslsmith,ou=people,dc=fcd,dc=test,dc=com, member: uid=amis,ou=people,dc=fcd,dc=test,dc=com, member:, uid=null,ou=people,dc=fcd,dc=test,dc=com"
# pattern definition
p = 'uid='
# holds user names
users = []
# split string on a space or a comma, find user id, append to list
for item in re.split(' |,|', mystring):
if item.startswith(p):
users.append(item.replace(p, ''))
print users