我有一个很长的html表单,我从中检索数据,然后填充到html文档中并通过电子邮件发送。我正在使用form = cgi.FieldStorage()从表单中获取发布的数据,然后我得到了一个类似于消息体的字符串(但长度大于mutch)

 msg = """<html><p>%(Frist_Name)s</p><p>%(Last_Name)s</p></html> """ % form


根据调试,它会一直工作直到找到未与表单一起提交的我的命名var之一。

表单上有很多可选字段,该怎么做才能完成这项工作或做类似的事情,所以我不必事先收集所有字段(即,手动重新输入每个字段),如果没有则创建一个空白字段?还是没有比这更简单的方法了?

最佳答案

设置默认值

my_data_dict = {'first_name':'','last_name':'','blah':'','something_else':''} #defaults with all values from format string
my_data_dict.update(form) #replace any values we got
 msg = """<html><p>%(Frist_Name)s</p><p>%(Last_Name)s</p></html> """ % my_data_dict


或使用默认字典(通过这种方式,您无需输入所有默认值,它们将变成神奇的“”)

from collections import defaultdict
my_dict = defaultdict(str)
print my_dict['some_key_that_doesnt_exist']  #should print empty string
my_dict.update(form)
msg = """<html><p>%(Frist_Name)s</p><p>%(Last_Name)s</p></html> """ % my_data_dict


或正如abarnert指出的,您可以将其简化为

from collections import defaultdict
my_dict = defaultdict(str,form)
msg = """<html><p>%(Frist_Name)s</p><p>%(Last_Name)s</p></html> """ % my_dict


这是我刚刚在终端中完成的一个完整示例

>>> d = defaultdict(str,{'fname':'bob','lname':'smith','zipcode':11111})
>>> format_str = "Name: %(fname)s  %(lname)s\nPhone: %(telephone)s\nZipcode: %(z
ipcode)s"
>>> d
defaultdict(<type 'str'>, {'lname': 'smith', 'zipcode': 11111, 'fname': 'bob'})
>>> #notice no telephone here
...
>>> d['extra_unneeded_argument'] =' just for show'
>>> d
defaultdict(<type 'str'>, {'lname': 'smith', 'extra_unneeded_argument': ' just f
or show', 'zipcode': 11111, 'fname': 'bob'})
>>> print format_str%d
Name: bob  smith
Phone:
Zipcode: 11111

07-28 02:51