我们在表格中查询数据,只需要点击那个功能键就可以了,不过这也是仅限于数据不多时候的使用。在我们数据比较多的时候,小编还是推荐用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学习网教学中心。