python检查密码字符串是否规范_Python检测字符串中是否包含某字符集合中的字符...

这篇文章介绍了Python中检测字符串是否包含某字符集合中的字符的几种方法,包括使用for循环和if条件判断,以及利用itertools模块提高效率。还提到了如何检查两个字符串的包含关系,并展示了使用set操作如difference和symmetric_difference来判断两序列的包含和差异。
摘要由CSDN通过智能技术生成

这篇文章主要介绍了Python检测字符串中是否包含某字符集合中的字符,需要的朋友可以参考下

sg_trans.gif

目的

检测字符串中是否包含某字符集合中的字符

方法

最简洁的方法如下,清晰,通用,快速,适用于任何序列和容器

代码如下:

def containAny(seq,aset):

for c in

seq:

if c in aset:

return True

return

False

第二种适用itertools模块来可以提高一点性能,本质上与前者是同种方法(不过此方法违背了Python的核心观点:简洁,清晰)

itertools.ifilter(predicate, iterable)的说明

Make an iterator that filters elements from iterable returning only

those for which the predicate is True. If predicate is None, return

the items that are true.

例如:

ifilter(lambda x: x%2, range(10)) --> 1 3 5 7 9

代码如下:

import itertools

def containAny(seq,aset):

for item in itertools.ifilter(aset.__contain__,seq):

return True

return False

如果要检测两个字符串是否为包含关系,此时必须检查所有子项,最好适用set类型,其中set(aset).difference(seq)是指存在于aset中而seq没有的元素:

代码如下:

def containAll(seq,aset):

return not set(aset).difference(seq)

例如下面这个例子:

复制代码代码如下:

In [4]: L1=[1,2,3,4]

In [5]: L2=[1,4,3,1]

In [6]:

containAll(L1,L2)

Out[6]: True

In [7]:

containAll(L2,L1)

Out[7]: False

注意一下,set.symmetric_difference是指两个集合独有的元素

代码如下:

In [9]: L2=[3,2,4,5]

In [10]: x=set(L1)

In [11]: x.symmetric_difference(L2)

Out[11]: set([1, 5])

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值