我正在尝试使用python正则表达式从GMAIL电子邮件正文中提取姓名,电话号码和电子邮件,而Zapier一直说未找到结果。
这是电子邮件的正文:
*****************************************************************
You received a new message from your online store's contact form.
*****************************************************************
Name:
-----
James Bacon
Phone:
------
3171234567
Email:
------
jamesb1234@gmail.com
Intentions:
-----------
my family
这是我的正则表达式:
Name:\n-----\n(.*)\n
Regex101.com说发现匹配很好,但Zapier一直说未找到结果。有什么想法吗?
答案 0 :(得分:1)
使用模式(Name|Phone|Email):.*?\n([^\n\-]+)\n(?=^.*?:)
(regex101 link):
data = '''*****************************************************************
You received a new message from your online store's contact form.
*****************************************************************
Name:
-----
James Bacon
Phone:
------
3171234567
Email:
------
jamesb1234@gmail.com
Intentions:
-----------
my family'''
import re
name = re.findall(r'Name:.*?\n([^\n\-]+)\n(?=^.*?:)', data, flags=re.DOTALL|re.M)
phone = re.findall(r'Phone:.*?\n([^\n\-]+)\n(?=^.*?:)', data, flags=re.DOTALL|re.M)
email = re.findall(r'Email:.*?\n([^\n\-]+)\n(?=^.*?:)', data, flags=re.DOTALL|re.M)
print(name)
print(phone)
print(email)
打印:
['James Bacon']
['3171234567']
['jamesb1234@gmail.com']
或一行:
g = re.findall(r'(Name|Phone|Email):.*?\n([^\n\-]+)\n(?=^.*?:)', data, flags=re.DOTALL|re.M)
print(g)
打印:
[('Name', 'James Bacon'), ('Phone', '3171234567'), ('Email', 'jamesb1234@gmail.com')]
这可以提供给dict
:
d = dict(re.findall(r'(Name|Phone|Email):.*?\n([^\n\-]+)\n(?=^.*?:)', data, flags=re.DOTALL|re.M))
print(d)
打印:
{'Name': 'James Bacon', 'Phone': '3171234567', 'Email': 'jamesb1234@gmail.com'}