python-正则表达式小练习

标题:正则表达式小练习

注:代码前的注释可任意删减,每个都是一个单独的小模块

# encoding=utf-8

import re

# 1.匹配某个字符串
#text = "hello"
# match可将正则表达式按照规则进行匹配
#ret = re.match('he',text)
# group 可将匹配到的字符串打印出来
#print(ret.group())

# 2.点.匹配任意的字符
#text = "hello"
# . 只能匹配一个字符, . 不能匹配换行符
#ret = re.match('.',text)
#print(ret.group())

# 3. \d : 匹配任意的数字(0-9)
#text = "0"
#ret = re.match('\d',text)
#print(ret.group())

# 4. \D : 匹配任意的非数字
#text = "a"
#ret = re.match('\D',text)
#print(ret.group())

# 5.\s 匹配的是空白字符(\n \t \r 空格)
#text = " \n "
#ret = re.match('\s',text)
#print(ret.group())

# 6.\w匹配到的是 a-z 和 A-Z 以及数字和下划线
#text = "a"
#ret = re.match('\w',text)
#print(ret.group())

# 7.\W 与 \w 相反
#text = "+"
#ret = re.match('\W',text)
#print(ret.group())

# 8.[]组合的方式,只要满足中括号中的字符,就可以匹配
#text = "0731-88888888"
# '[\d\-]' 只能匹配一个字符
# '[\d\-]+' 可以匹配多个字符
#ret = re.match('[\d\-]+',text)
#print(ret.group())

# 8.1. 中括号的形式代替 \d
#text = "09"
# ^ : 非 0-9 间的字符
#ret = re.match('[^0-9]',text)
#print(ret.group())

# 8.2.中括号的形式替换 \D

#text = "a"
#ret = re.match('[^0-9]',text)
#print(ret.group())

# 8.3.中括号的形式替换 \w
#text = "b"
#ret = re.match('[a-zA-Z0-9_]',text)
#print(ret.group())

# 8.4.中括号的形式替换 \W
#text = "+"
#ret = re.match('[^a-zA-Z0-9_]',text)
#print(ret.group())

###########匹配多个字符########
# 9. *:可以匹配0或多个任意字符
#text = "0731"
#ret = re.match('\d*',text)
#print(ret.group())

# 10. +匹配一个或多个字符
#text = "0731"
#ret = re.match('\w+',text)
#print(ret.group())

# 11. ?匹配一个或0个(要么没有,要么就只有一个)
#text = "0731"
#ret = re.match('\w?',text)
#print(ret.group())

# 12. {m}: 匹配 m个字符
#text = "0731"
#ret = re.match('\w{2}',text)
#print(ret.group())

# 13. {m,n}:匹配 m-n个字符
#text = "0731"
#ret = re.match('\w{1,3}',text)
#print(ret.group())

############小案例##########
# 1.验证手机号码:
#text = "18578900987"
#ret = re.match('1[34578]\d{9}',text)
#print(ret.group())

# 2.验证邮箱:
#text = "hynever12_@qq.com"
# '\w+': 最少要有一个
# \w+@[a-z0-9]+\.    \:转译
#ret = re.match('\w+@[a-z0-9]+\.[a-z]+',text)
#print(ret.group())

# 3.验证url:
#text = "https://baike.sogou.com/v58828.htm?fromTitle=Python"
# | 或
#ret = re.match('(http|https|ftp)://[^\s]+',text)
#print(ret.group())

# 4.验证身份证:
#text = "31131118908123230x"
#ret = re.match('\d{17}[\dxX]',text)
#print(ret.group())

# ^(脱字号): 表示以 … 开始
#text = "hello"
#ret = re.search('^h',text)
#print(ret.group())

# $ :表示以 … 结尾:
#text = "xxx@163.com"
#ret = re.match('\w+@163.com$',text)
#print(ret.group())

# | :匹配多个表达式或字符串
#text = "http"
# (http|fps|https): 必须以()中内容结尾
#ret = re.match('(http|fps|https)$',text)
#print(ret.group())

# 贪婪模式和非贪婪模式:
#text = "0123456"
# '\d+' : 默认贪婪模式
# '\d+?' : 默认非贪婪模式
#ret = re.match('\d+?',text)
#print(ret.group())

# 非贪婪模式
#text = "<h1>标题</h1>"
#ret = re.match('<.+?>',text)
#print(ret.group())

# 匹配0-100间的数字
# 可以出现 1,2,3,100.99
# 有三种情况:1,99,100
# 不可以出现 09 101
text = "55"
# [1-9]\d? 满足 10
ret = re.match('[1-9]\d?$|100$',text)
print(ret.group())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值