Python核心编程——Chapter15
正则表达式在脚本语言里是最重要的一部分,这部分的题目真的不容怠慢。
开始这部分的题目的解答!
15.1识别下列字符串:bat,bit,but,hat,hit和hut。
>>> import re
>>> pattern='[bh][aiu]t'
>>> word='batsasasasa'
>>> m=re.search(pattern,word)
>>> if m is not None:
... m.group()
...
'bat'
15.2.匹配用一个空格分隔的任意一对单词,比如名和性。
pattern='[A-Za-z][a-z]+ [A-Za-z][a-z]'
15.3.匹配用一个逗号和一个空格分开的一个单词和一个字母。
>>> import re
>>> pattern='([A-Z]\.)+ ?[A-Z][a-z]+'
>>> s1='J.R. Smith'
>>> s2='J.R.Smith'
>>> s3='T. Ford'
>>> re.match(pattern,s1).group()
'J.R. Smith'
>>> re.match(pattern,s2).group()
'J.R.Smith'
>>> re.match(pattern,s3).group()
'T. Ford'
15.4.匹配所有合法的Python标识符
所谓合法的Python标识符:首字母只能是下划线或字母,然后之后的字符可以是字母,数字或下划线。
>>> pattern='[a-zA-Z_][\w_]+'
15.5.匹配美国的街道名字地址,如:1180 Bordeaux Drive ,3120 De la Cruz Boulevard。
>>> patter='\d+ [A-Za-z ]+'
15.6.匹配以“www."开头,以”.com"作结尾的Web域名。
>>> pattern='w{3}[.\w]+.com'
附加题:支持其他顶级域名:
>>> pattern='w{3}[.\w]+'
15.7.匹配全体Python整型的字符串表示形式的集合。
>>> pattern='\d+[Ll]?'
15.8.匹配全体Python长整型字符串表示形式的集合。
>>> pattern='\d+[Ll]'
15.9.匹配全体Python浮点型的字符串表示形式的集合。
>>> pattern='\d+\.\d+'
15.10.匹配全体Python复数的字符串表示形式的集合。
>>> pattern='\d+\.?\d+\+\d+\.?\d+j'
15.11.匹配所有合法的电子邮件地址
>>> pattern='\w+@[\w.]+'
15.13.往type()提取类型的名字
>>> pattern=''
>>> re.match(pattern,"<type 'int'>").group()
"<type 'int'>"
>>> re.match(pattern,"<type 'int'>").group(1)
'int'
15.16.将gendata.py的内容输出到文件当中。
#!/usr/bin/env python from random import randint,choice
from string import lowercase
from sys import maxint
from time import ctime doms = ('com','edu','net','org','gov')
g = open('/home/dzhwen/456.txt','a+') for i in range(randint(5,10)):
dtint = randint(0,maxint-1)
dtstr = ctime(dtint)
shorter = randint(4,7) em =''
for j in range(shorter):
em += choice(lowercase) longer = randint(shorter,12)
dn=''
for j in range(longer):
dn += choice(lowercase) word=dtstr+'::'+em+'@'+dn+'.'+choice(doms)+'::'+str(dtint)+'-'+str(shorter)+'-'+str(longer)+'\n'
g.write(word)
15.19.提取出每行中完整的时间戳字段。
#!/usr/bin/env python
import re
f = open('/home/dzhwen/456.txt','r')
pattern = '(.+?)::.+'
for eachLine in f:
m = re.match(pattern,eachLine)
print m.group(1)
15.20.提取出每行中完整的电子邮件地址。
#!/usr/bin/env python
import re
f = open('/home/dzhwen/456.txt','r')
pattern = '.+::(\w+@\w+.\w+)::.+'
for eachLine in f:
m = re.match(pattern,eachLine)
print m.group(1)
15.21.只提取时间戳字段中的月份。
#!/usr/bin/env python
import re
f = open('/home/dzhwen/456.txt','r')
pattern = '\w{3} (\w{3}).+'
for eachLine in f:
m = re.match(pattern,eachLine)
print m.group(1)
15.22.只提取时间戳字段中的年份。
#!/usr/bin/env python
import re
f = open('/home/dzhwen/456.txt','r')
pattern = '.+?(\d{4}).+'
for eachLine in f:
m = re.match(pattern,eachLine)
print m.group(1)
15.23.只提取出时间戳字段中的时间值。
#!/usr/bin/env python
import re
f = open('/home/dzhwen/456.txt','r')
pattern = '.+(\d{2}:\d{2}:\d{2}).+'
for eachLine in f:
m = re.match(pattern,eachLine)
print m.group(1)
15.25.只从电子邮件地址中提取出登录名和域名。(二者分别提取)
#!/usr/bin/env python
import re
f = open('/home/dzhwen/456.txt','r')
pattern = '.+::(\w+)?@(.+)?::.+'
for eachLine in f:
m = re.match(pattern,eachLine)
print m.group(1),m.group(2)
15.26.将每行中的电子邮件地址替换为你自己的电子邮件地址。
#!/usr/bin/env python
#-*-coding:utf-8-*- import re f = open('/home/dzhwen/456.txt','r') pattern = '.+::(.+)?::.+' for eachLine in f:
m = re.match(pattern,eachLine)
address = raw_input('请输入你自己的电子邮件:')
print re.subn(m.group(1),address,eachLine)
有趣的题目基本只有这些,请多多指教!
Python核心编程——Chapter15的更多相关文章
- python核心编程第二版笔记
python核心编程第二版笔记由网友提供:open168 python核心编程--笔记(很详细,建议收藏) 解释器options:1.1 –d 提供调试输出1.2 –O 生成优化的字节码(生成 ...
- python核心编程--笔记
python核心编程--笔记 的解释器options: 1.1 –d 提供调试输出 1.2 –O 生成优化的字节码(生成.pyo文件) 1.3 –S 不导入site模块以在启动时查找pyt ...
- Python核心编程第二版(中文).pdf 目录整理
python核心编程目录 Chapter1:欢迎来到python世界!-页码:7 1.1什么是python 1.2起源 :罗萨姆1989底创建python 1.3特点 1.3.1高级 1.3.2面向 ...
- python核心编程--笔记(不定时跟新)(转)
的解释器options: 1.1 –d 提供调试输出 1.2 –O 生成优化的字节码(生成.pyo文件) 1.3 –S 不导入site模块以在启动时查找python路径 1.4 –v ...
- python核心编程笔记(转)
解释器options: 1.1 –d 提供调试输出 1.2 –O 生成优化的字节码(生成.pyo文件) 1.3 –S 不导入site模块以在启动时查找python路径 1.4 –v 冗 ...
- python核心编程(第二版)习题
重新再看一遍python核心编程,把后面的习题都做一下.
- Python核心编程这本书的一些错误
<Python核心编程第二版>这本书比<Python基础教程第二版修订版>详细很多,丰富了很多细节,虽然它是一本经典的入门书,但我发现还是存在一些明显的错误.在面向对象编程这一 ...
- Python核心编程-描述符
python中,什么描述符.描述符就是实现了"__get__"."__set__"或"__delete__" 方法中至少一个的对象.什么是非 ...
- Python核心编程-闭包
百度搜了一下闭包的概念:简而言之,闭包的作用就是在外部函数执行完并返回后,闭包使得收机制不会收回函数所占用的资源,因为内部函数的执行需要依赖外函数中的变量.这是对闭包作用的非常直白的描述,不专业也不严 ...
随机推荐
- iOS完整学习路线图-对知识的回顾/整理
第一阶段:语言基础 Mac系统使用.常用UNIX指令.C语言.Objective-C语言.Foundation框架. 第二阶段:iOS基础 AppDelegate & UIApplicatio ...
- Scrum项目6.0 和8910章读后感
Scrum项目6.0总结 这次sprint1通过我们的努力,终于把自动回复做出来了.但之后的任务更加繁重,我们要更加努力,克服各种困难. 也要说说这次自动回复里面的注意之处: 1.不该空格的地方空格, ...
- HDU 2140 Michael Scofield's letter
http://acm.hdu.edu.cn/showproblem.php?pid=2140 Problem Description I believe many people are the fan ...
- PHP 官方发行版扩展下载地址
PHP扩展下载 稳定发行版资源下载地址: https://windows.php.net/downloads/pecl/releases/ 常用扩展: 持续更新中 ... igbinary序列化/反序 ...
- Java 软引用和弱引用
软引用(SoftReference) 软引用是用来描述一些有用但并不是必需的对象,在Java中用java.lang.ref.SoftReference类来表示.对于软引用关联着的对象,只有在内存不足的 ...
- Atcoder arc080E Young Maids(线段树+优先队列)
给出一个n排列,每次可以选择相邻的两个数字放在新的排列首部,问最后形成的新的排列字典序最小是? 考虑新排列的第一个数字,则应是下标为奇数的最小数,下标不妨设为i.第二个数字应该下标大于i且为偶数的最小 ...
- 【Java并发编程】之九:死锁
当线程需要同时持有多个锁时,有可能产生死锁.考虑如下情形: 线程A当前持有互斥所锁lock1,线程B当前持有互斥锁lock2.接下来,当线程A仍然持有lock1时,它试图获取lock2,因为线程B ...
- Windows平台下在服务中添加MySQL
widows下查看服务 1.桌面计算机-->右键-->管理-->计算机管理(本地)--->服务和应用程序-->服务 2.运行 中输入 services.msc 在服务中添 ...
- 【BZOJ1858】序列操作(线段树)
[BZOJ1858]序列操作(线段树) 题面 BZOJ 题解 这题思路很简单,细节很烦,很码 维护区间翻转和区间赋值标记 当打到区间赋值标记时直接覆盖掉翻转标记 下放标记的时候先放赋值标记再放翻转标记 ...
- 51nod 1218 最长递增子序列 | 思维题
51nod 1218 最长递增子序列 题面 给出一个序列,求哪些元素可能在某条最长上升子序列中,哪些元素一定在所有最长上升子序列中. 题解 YJY大嫂教导我们,如果以一个元素结尾的LIS长度 + 以它 ...