正则表达式在脚本语言里是最重要的一部分,这部分的题目真的不容怠慢。

开始这部分的题目的解答!

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的更多相关文章

  1. python核心编程第二版笔记

    python核心编程第二版笔记由网友提供:open168 python核心编程--笔记(很详细,建议收藏) 解释器options:1.1 –d   提供调试输出1.2 –O   生成优化的字节码(生成 ...

  2. python核心编程--笔记

    python核心编程--笔记 的解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找pyt ...

  3. Python核心编程第二版(中文).pdf 目录整理

    python核心编程目录 Chapter1:欢迎来到python世界!-页码:7 1.1什么是python 1.2起源  :罗萨姆1989底创建python 1.3特点 1.3.1高级 1.3.2面向 ...

  4. python核心编程--笔记(不定时跟新)(转)

    的解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找python路径 1.4 –v   ...

  5. python核心编程笔记(转)

    解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找python路径 1.4 –v   冗 ...

  6. python核心编程(第二版)习题

    重新再看一遍python核心编程,把后面的习题都做一下.

  7. Python核心编程这本书的一些错误

    <Python核心编程第二版>这本书比<Python基础教程第二版修订版>详细很多,丰富了很多细节,虽然它是一本经典的入门书,但我发现还是存在一些明显的错误.在面向对象编程这一 ...

  8. Python核心编程-描述符

    python中,什么描述符.描述符就是实现了"__get__"."__set__"或"__delete__" 方法中至少一个的对象.什么是非 ...

  9. Python核心编程-闭包

    百度搜了一下闭包的概念:简而言之,闭包的作用就是在外部函数执行完并返回后,闭包使得收机制不会收回函数所占用的资源,因为内部函数的执行需要依赖外函数中的变量.这是对闭包作用的非常直白的描述,不专业也不严 ...

随机推荐

  1. Python入门:条件控制

    条件控制其实就是if...else...(如果...条件是成立的,就做...:反之,就做...)的使用,其基本结构是: 具体看下面这个例子: def account_login(): # 定义函数 p ...

  2. git 常用命令总结(一)

    1.初始化版本库: .进入工程根目录目录 .创建项目目录 mkdir 项目目录名称 .进入创建的项目中 cd 项目名称 pwd 显示当前目录 .项目初始化 git init //完成后会在项目目录下生 ...

  3. strtr、str_replace()、substr_replace、preg_replace之间的区别

    strtr(string, from, to): 逐个字符开始替换,以from跟to中长度较较短的一个为准,例如: strtr("aidengni","ai", ...

  4. Java 软引用和弱引用

    软引用(SoftReference) 软引用是用来描述一些有用但并不是必需的对象,在Java中用java.lang.ref.SoftReference类来表示.对于软引用关联着的对象,只有在内存不足的 ...

  5. 栈java实现

    这几天,过得挺充实的,每天都在不停的上课,早上很早就起来去跑步,晚上到图书馆看书.一边紧张的学习,一边在默默的备战软考.最近还接手了一个公司官网的建设.这是我在川信最后的一个完整学期了,每件事我都要认 ...

  6. ios开发之 -- xib关联自定义view

    在xib下使用自定义的view,因为很多时候,可能幸亏自顶一个view,然后在view里面填充控件,但是需要重写很多无用的 代码,而且很容易出错不说,还很好工作量,使用xib的话,分钟搞定一个view ...

  7. js模块化的总结

    从前端打包的历史谈起 在很长的一段前端历史里,是不存在打包这个说法的.那个时候页面基本是纯静态的或者服务端输出的, 没有 AJAX,也没有 jQuery.Google 推出 Gmail 的时候(200 ...

  8. 【IOI 2018】Highway 高速公路收费

    这是一道极好的图论题,虽然我一开始只会做$18$分,后来会做$51$分,看着题解想了好久才会做(吐槽官方题解:永远只有一句话),但这的确是一道好题,值得思考,也能启发思维. 如果要讲这道题,还是要从部 ...

  9. Kerberos无约束委派的攻击和防御

    0x00 前言简介 当Active Directory首次与Windows 2000 Server一起发布时,Microsoft就提供了一种简单的机制来支持用户通过Kerberos对Web服务器进行身 ...

  10. Active Directory PowerShell模块收集AD信息

    0x00 前言简介 Microsoft为Windows Server 2008 R2(以及更高版本)提供了多个Active Directory PowerShell cmdlet,这大大简化了以前需要 ...