我们在表格中查询数据,只需要点击那个功能键就可以了,不过这也是仅限于数据不多时候的使用。在我们数据比较多的时候,小编还是推荐用python中的模块来进行解决,比如最近一直在讲的re模块就非常好用。那么其中有没有能够进行匹配满足条件选项的函数呢?我们一起往下看:
编写一个程序,复制一段文本到剪贴板后,运行程序,自动找出文本所有的电话号码和邮件地址,并复制到剪贴板供用户使用。
思路:
从剪贴板中获取文本
匹配出所有的电话号码和邮件地址
将它们粘贴到剪贴板
实现:
使用pyperclip模块复制或粘贴字符串,pyperclip 需要使用pip安装
创建两个正则表达式,一个匹配电话,另一个匹配邮件地址
将匹配好的字符串整理好,处理一下格式,发送给剪贴板
如果没有找到匹配,报错或提示用户
代码:
#!/usr/bin/envpython3
#-*-coding:utf-8-*-
#author:Windrivder
#email:windrivder@gmail.com
#date:17/03/2712:58:05
importre,pyperclip
#匹配电话
phoneRegex=re.compile(r'''(
^(13[0-9]|#匹配13开头的电话
14[5|7]|
15[0|1|2|3|5|6|7|8|9]|
18[0|1|2|3|5|6|7|8|9])
\d{8}$
)''',re.VERBOSE)#如上,传入参数re.VERBOSE可以给正则表达式添加注释,详见附录
#匹配邮件地址
emailRegex=re.compile(r'''(
[a-zA-Z0-9._%+-]+#email-username
@
[a-zA-Z0-9.-]+#domain-name
(\.[a-zA-Z]{2,4})#dot-something
)''',re.VERBOSE)
#从剪贴板中获取字符串
text=str(pyperclip.paste())
#存放匹配到的字符串
matches=[]
forphoneinphoneRegex.findall(text):
matches.append(phone[0])
foremailinemailRegex.findall(text):
matches.append(email[0])
#将匹配到的字符串复制到剪贴板
iflen(matches)>0:
pyperclip.copy('\n'.join(matches))
print('Copiedtoclipboard:')
print('\n'.join(matches))
else:
print('Nophoneoremailfound.')
小伙伴们可以先理清开头的思路,然后再进行代码的复制尝试,看看是不是能提取出文本中的电话号码呢?更多Python学习推荐:PyThon学习网教学中心。