重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这里写反斜杠也是转义的意思,python在re模块中使用都需要加反斜杠
成都创新互联公司成立十年来,这条路我们正越走越好,积累了技术与客户资源,形成了良好的口碑。为客户提供成都网站建设、网站建设、网站策划、网页设计、域名与空间、网络营销、VI设计、网站改版、漏洞修补等服务。网站是否美观、功能强大、用户体验好、性价比高、打开快等等,这些对于网站建设都非常重要,成都创新互联公司通过对建站技术性的掌握、对创意设计的研究为客户提供一站式互联网解决方案,携手广大客户,共同发展进步。
他和match有相同的作用,但是有区别。他会在整个字符串内容中匹配,直到找到第一个相匹配的字符串。
他和match和search差不多,但是他是找出字符串中所有的
import re
result1 = re.match('\d+','dshfjasdsf23432dhfhsjdjfhjsd')
if result1:
print result1.group()
result2 = re.search('\d+','dshfjasdsf23432dhfhsjdjfhjsd')
print result2
print result2.group()
result3 = re.findall('\d+','dshfjasdsf23432dhfhsjdjfhjsd34')
print result3
#输出结果:
<_sre.SRE_Match object at 0x0000000002BFA510>
23432
['23432', '34']
他和编译生成的.pyc文件差不多,.pyc是为了再次使用时快速调用。正则表达式也可以经过编译,编译之后匹配其他的也会加快匹配速度
com = re.compile('\d+')
print type(com)
输出结果:
他返回了一个对象
com = re.compile('\d+')
print com.findall('dshfjasdsf23432dhfhsjdjfhjsd34')
import re
f = open('love.txt','r')
feitian = f.read()
f.close()
print re.findall('a',feitian)
##也可以一行一行的匹配
f = open("love.txt", "r")
while True:
line = f.readline()
if line:
line=line.strip()
p=line.rfind('.')
filename=line[0:p]
print line
else:
break
f.close()
输出:
['a', 'a', 'a']
result2 = re.search('(\d+)\w*(\d+)','dshfjasdsf23432dhfhs23423jdjfhjsd')
print result2.group()
print result2.groups()
#输出结果:
23432dhfhs23423
('23432', '3')
#注意: 他不重复拿,这里解释一下为什么第二个输出为3,因为中间都被\w*接收了,这里我们在给一个例子
result2 = re.search('(\d+)dhfhs(\d+)','dshfjasdsf23432dhfhs23423jdjfhjsd')
print result2.group()
print result2.groups()
输出结果:
23432dhfhs23423
('23432', '23423')
import re
ip = 'sdhflsdhfj1723.234.234234.df.34.1234.df.324.xc.3+dsf172.25.254.1 sdfjk2130sdkjf.sdjfs'
result1 = re.findall('(?:\d{1,3}\.){3}\d{1,3}',ip)
result2 = re.findall('[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}',ip)
print result1
print result2
#输出结果:
['172.25.254.1']
['172.25.254.1']
import time
print time.time()
1510923748.06
#计算从1970年1月1日到现在有多少秒
print time.gmtime()
time.struct_time(tm_year=2017, tm_mon=11, tm_mday=17, tm_hour=13, tm_min=2, tm_sec=28, tm_wday=4, tm_yday=321, tm_isdst=0)
格式化成一个对象,他是当前的时间
print time.strftime('%Y%m%d')
20171117
输出格式化之后的时间,他的格式化和linux一样
print time.strptime('2017-11-17','%Y-%m-%d')
time.struct_time(tm_year=2017, tm_mon=11, tm_mday=17, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=4, tm_yday=321, tm_isdst=-1)
#将字符串转化成结构化的时间格式
print time.localtime()
print time.mktime(time.localtime())
time.struct_time(tm_year=2017, tm_mon=11, tm_mday=17, tm_hour=21, tm_min=17, tm_sec=57, tm_wday=4, tm_yday=321, tm_isdst=0)
1510924677.0
#结构化的时间转化成时间戳的格式
#字符串格式的时间转时间戳格式他不能直接转,必须要中转
第一部分时间戳形式存在,第二部分以结构化形式存在,第三部分以字符串形式存在