Problem: 将第 0015 题中的 city.xls 文件中的内容写到 city.xml 文件中,如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
<?xmlversion="1.0" encoding="UTF-8"?>
<root>
<citys>
<!--
城市信息
-->
{
"1" : "上海",
"2" : "北京",
"3" : "成都"
}
</citys>
</root>

Solution: Write Excel Data to XML II, Python:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#!/usr/bin/env python
# -*- encoding: utf-8 -*-
# @Date : 2015-03-27 12:26:06
# @Author : NSSimacer
# @Version : 1.0
import sys
from xlrd import open_workbook
from xml.dom import minidom
# 设置系统编码为 UTF-8,处理中文乱码问题
reload(sys)
sys.setdefaultencoding('utf-8')
def write_data_to_xml(dict_conent):
'''
将 dict 格式数据写入 xml 文件
'''
xml_doc = minidom.Document()
root = xml_doc.createElement('root')
xml_doc.appendChild(root)
city = xml_doc.createElement('city')
root.appendChild(city)
comment = xml_doc.createComment('城市信息')
city.appendChild(comment)
content = xml_doc.createTextNode(str(dict_conent))
city.appendChild(content)
with open('city.xml', 'wb') as f:
f.write(xml_doc.toprettyxml(encoding='utf-8'))
def load_data_as_dict(f_path):
'''
从 Excel 文件中读取数据,以 dict 格式返回
'''
dict_conent = {}
workbook = open_workbook(f_path, encoding_override='utf-8')
sheet = workbook.sheet_by_name('city')
for row in xrange(sheet.nrows):
dict_conent[str(row + 1)] = str(sheet.row_values(row)[1:])
return dict_conent
def main():
f_path = 'city.xlsx'
dict_conent = load_data_as_dict(f_path)
write_data_to_xml(dict_conent)
if __name__ == '__main__':
main()

第 0017 题相似。

题目来源:Python 练习册,每天一个小程序 THX!