pythonlist元素判断
‘壹’ python判断列表中是否有重复元素
举个栗子:
原数组长度,与去重后的数据,判断长度,长度相等,则证明无重复项,不相等就说明有重复项
str=[1,2,3,4,5]
iflen(str)==len(set(str)):
print"nomp"
else:
print"mp"
‘贰’ python 判断列表中每个元素有几个
比如你可以这样(用isinstance()函数来判断类型):
123456789intCount = 0 #用来记录列表中的int元素个数listCount = 0 #记录list元素个数a = [1,'a',2,[1,2]]for i in a: #遍历a if isinstance(i,int): #判断i是不是int intCount += 1 elif isinstance(i,list): #判断i是不是list listCount += 1print(intCount,listCount)
结果是2 1,也就是有2个int元素,1个list元素。
这是一个思路,你可以根据需要添加判断的类型,比如要统计float类型,就可以再加个elif isinstance(i,list)来进行统计。至于元素种类,对应的记录是0,就说明没有这个种类的元素,比如如果intCount是0,就说明列表中没有int元素。
‘叁’ python 判断list中的元素是否是需要的文件夹名称
importos
path_base=r'C:pythonstudyfirstpartproqual_cemcases'
target_path=r'C:pythonstudyfirstpart'
alist=['1','2','3','4','5']
deffun(path):
files=[]
forroot,dirs,filesinos.walk(path):
forfninfiles:
files.append(os.path.join(root,fn))
returnfiles
forxinalist:
path=os.path.join(path_base,x)
ifos.path.isdir(path):
files=fun(path)
forfileinfiles:
filename=os.path.split(file)[1]
open(os.path.join(target_path,filename),"wb").write(open(file,"rb").read())
代码未经测试,提供思路给你参考一下吧
‘肆’ python实现给定一个列表判断里面是否有重复元素
有两个方法:
使用列表的count方法,因为count方法可以做对象内的元素进行出现次数叠加计算
list1=[1,2,3,4,4,5,6,7]
list1.count(1)#结果为1
list1.count(4)#结果为2
foriinlist1:
iflist1.count(i)>=2:
print('该元素%s重复'%i)
#结果:
该元素4重复
该元素4重复#因为迭代了两次4所以有两次输出,功能是实现了,但是却打印了两次,有点不理想
2.借用工厂函数set()把对象转为集合和列表的方法(浅复制),集合会默认把重复元素去掉
list1=[1,2,3,4,4,5,6,7]
list2=list1.()#为了不破坏原数据,临时浅复制给变量list2
list3=list(set(list2))#使用set()函数将list2转为集合去掉重复元素又用list()转回列表
foriinlist3:#对无重复元素的列表list3迭代
ifiinlist2:
list1.remove(i)#当list3内的元素存在于list2中,则把其元素从list2中删除,最后就会留下重复元素
print('list1:%s中的重复元素有:%s'%(list1,list2))#组后输出原数据list1和最终结果list2
#结果:
list1:[1,2,3,4,4,5,6,7]中的重复元素有:[4]
#效果实现了,也没问题,就是变量使用有点多。看你选择了
‘伍’ Python中如何判断一个元素在list中,用while!!!不要in!谢谢~
L=[1,2,3]
a=1
i=0
a_in_L=False
whilei<len(L):
ifa==L[i]:
a_in_L=True
break
print('ais{}inL'.format(''ifa_in_Lelse'not'))
‘陆’ python判断元素是否在列表组中
locals()函数会以字典类型返回当前位置的全部局部变量。
对于函数, 方法, lambda 函式, 类, 以及实现了 __call__ 方法的类实例, 它都返回 True。
def chuli():
list1 = ['A', 'B1', 'C', 'D6', 'E2', 'F4']
list2 = ['G', 'H', 'K45', 'J4', 'K', 'L7']
list3 = ['M3', 'N', 'O5', 'P', 'Q43', 'R']
# 在这里有100个列表
list100 = ['S2', 'W5', 'R8', 'T', 'W', 'E']
# locals() 函数会以字典类型返回当前位置的全部局部变量。
# 对于函数, 方法, lambda 函式, 类, 以及实现了 __call__ 方法的类实例, 它都返回 True。
dc = locals()
for key, val in dc.items():
if 'K45' in val:
print(key)
chuli()
‘柒’ python 要怎么判断list是否超出索引范围
题主你好,
可以利用len()函数进行判断. 详细逻辑如下:
假设我的列表为: a=['2022-06-24','2022-06-25','2022-06-26','2022-06-27','2022-06-28']
我先使用len()函数拿到列表a的长度,并将该长存到变量length中: length = len(a)
而列表索引的取值是以0为起始,以列表的长度减1结束,拿本例来说,列表a的索引取值范围就是a[0]到a[4]共5个元素.
因此题主在判断时,可以直接使用索引值和列表的最大索引进行比较,也就是和拿本例来说也就是和len(a)-1进行比较, 拿题主中提问中的例子来说就是用 7和len(a)-1进行比较,如果7小于等于len(a)-1则说明7这个索引没有超出列表的索引范围,反之.
-----
方法二: 利用异常捕获结构:
*.上面两种方法写的不是很好, 但希望可以给题主提供一些解题思路.
-----
扩展阅读: 网页链接
=====
希望可以帮到题主, 欢迎追问.
‘捌’ python如何判断一个数组里面的元素是否有相同的
可以对第二个list的元素进行遍历,检查是否出现在第二个list当中,如果使用表理解,可以使用一行代码完成任务。
list1 = [1,2,3,4,5]
list2 = [4,5,6,7,8]
print [l for l in list1 if l in list2]
# [4,5]
如果每一个列表中均没有重复的元素,那么还有另外一种更好的办法。首先把两个list转换成set,然后对两个set取交集,即可得到两个list的重复元素。
set1 = set(list1)
set2 = set(list2)
print set1 & set 2
# {4,5}
‘玖’ python中如何判断list中是否包含某个元素
index方法 表示在list中查找元素的位置。没有查找到元素会报错。
count方法 表示在list中查找元素的个数。没有为0
‘拾’ python 判断两个list 是否有相同的元素
最简单的方法:将两个list均变为集合set,求集合的交集,若交集不为空则有相同元素。且由此方法确定了有哪些相同元素,再可将交集转为列表。