使用较少的代码

时间:2018-03-14 02:28:12

标签: python python-2.7 iteration

我的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

2 个答案:

答案 0 :(得分:1)

如果您还没有尝试过正则表达式:

import re
r = re.compile(r'uid=(\w+)')
r.findall(mystring)

如果要删除空值,可以filter(lambda x: x != 'null', r.findall(mystring))(再重复一次)

这个正则表达式有效,但也会删除以单词null

开头的所有uid
re.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