免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2046 | 回复: 4
打印 上一主题 下一主题

正则表达式请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-07-11 20:49 |只看该作者 |倒序浏览
假如我们有一个数字串,要怎么判断这个字串是否包含0-9十个数字呢?
本来想用正则表达式来处理,但想了想不知道要怎么表达?
请大家一起提供一下思路。

条件:
1。数字串长度不定
2。数字出现的顺序,位置不定

如:1982736450,
      1234567890,
       0987654321,
       1357924680938275
       这些都应该是符合条件的.

论坛徽章:
0
2 [报告]
发表于 2010-07-11 22:59 |只看该作者
这道题不用正则,会不会更方便一些?
  1. import re
  2. s="12345678012933"
  3. n=re.findall(r'\d+',s)[0]
  4. a=[i for i in range(10) if str(i) not in n]
  5. print a
复制代码

论坛徽章:
0
3 [报告]
发表于 2010-07-12 09:36 |只看该作者
也是哦,
不過我看上面的代碼,n和s都是一樣的值,
為什麼要多這一行呢.

import re

s="12345678012933"
a=[i for i in range(10) if str(i) not in s]
print a

這樣不是可以少一行嗎?

论坛徽章:
0
4 [报告]
发表于 2010-07-12 09:52 |只看该作者
剛才找到一個比較簡單的方法.

s='123456789017643'
a=set(s).__len__()

如a=10,則表示這個數字串中包含所有數字.

论坛徽章:
0
5 [报告]
发表于 2010-07-12 16:37 |只看该作者
剛才找到一個比較簡單的方法.

s='123456789017643'
a=set(s).__len__()

如a=10,則表示這個數字串中包 ...
vnsoft 发表于 2010-07-12 09:52

这个好。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP