我有嵌套lists.in这个列表,每个嵌套列表包含两个组件,每个组件可能包含空格('')字符。我想删除并编写一段代码,但无法使其工作。如何我克服了这个问题?
列表的嵌套列表是:
[['bike', '2 * wheel+1* frame'], ['wheel', '1 * rim + 1* spoke +1 *hub'], ['rim', 60], ['spoke', 120], ['hub', '2*gear+1*axle'], ['gear', 25], ['axle', '5*bolt+7*nut'],['bolt',0.1], ['nut', 0.15],['frame', '1*rearframe+ 1*frontframe'],['rearframe', 175],['frontframe', '1*fork+2*handle'], ['fork', 22.5],['handle', 10.0]]
正如所见,某些字符串中有一些空白。
我写的python代码:
def blanks(des):
a = 0
while a < len(des):
if type(des[0][1]) == str:
des[0][0] = des[0][0].replace(' ','')
if type(des[0][1]) == str:
des[0][1] = des[0][1].replace(' ','')
a += 1
return des
答案 0 :(得分:1)
改为使用for
循环。
def blanks(lis):
for i, _ in enumerate(lis):
for j in range(2):
if isinstance(lis[i][j], str):
lis[i][j] = lis[i][j].replace(' ', '')
return lis
列表理解也可以。
def blanks(lis):
return [i.replace(' ', '') if isinstance(i, str) else i for a in lis for i in a]
或者只是没有功能定义:
lis = [[i.replace(' ', '') if isinstance(i, str) else i for i in a] for a in lis]
我认为这应该做你想要的。但是,如果您的嵌套列表具有不一致的深度,那么最好使用生成器函数。
def blanks(lis):
for i, el in enumerate(lis):
if isinstance(el, list):
blanks(el)
elif isinstance(el, str):
yield el.replace(' ', '')
else:
yield el
有关最后一段代码的更多信息,另请参阅this answer。
答案 1 :(得分:0)
这是一种方法:
map(lambda x:map(lambda y:y.replace(' ','') if isinstance(y,str) else y,x),a)
其中a
是您传递的输入列表。
答案 2 :(得分:0)
好的,因为没有限制或任何固定的参数,你将不得不使用一点点的递归来解决你的问题。
def trimSpaces(list):
for i in range(0,len(list)):
if type(list[i]) == str:
list[i] = list[i].replace(' ','')
elif type(list[i]) == type([]):
list[i] = trimSpaces(list[i])
else:
continue
return list
答案 3 :(得分:0)
试试这个:
def removeBlanks(input):
if type(input) is list:
ret=[]
for i in input:
ret.append(removeBlanks(i))
else:
ret=input.replace(" ", "")
return ret
答案 4 :(得分:0)
在python中,您通常希望关注EAFP并捕获异常,而不是使用isinstance
预先验证输入:
def no_blanks(s):
try:
return s.replace(' ', '')
except AttributeError:
return s
ls = [['bike', '2 * wheel+1* frame'], ['wheel', '1 * rim + 1* spoke +1 *hub'], ['rim', 60], ['spoke', 120], ['hub', '2*gear+1*axle'], ['gear', 25], ['axle', '5*bolt+7*nut'],['bolt',0.1], ['nut', 0.15],['frame', '1*rearframe+ 1*frontframe'],['rearframe', 175],['frontframe', '1*fork+2*handle'], ['fork', 22.5],['handle', 10.0]]
new_ls = [[no_blanks(a), no_blanks(b)] for a, b in ls]
同样仔细查看您的列表,我认为dict
可能是您数据的更好选择。