1

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

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

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

表单上有许多可选字段,我可以做些什么来完成这项工作或做类似的事情,这样我就不必事先收集所有字段(即手动重新输入每个字段)并在没有时创建一个空白字段?或者没有比这更简单的方法了吗?

4

1 回答 1

2

设置默认值

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
于 2013-05-06T18:53:16.197 回答