Problem: 将第 0016 题中的 numbers.xls 文件中的内容写到 numbers.xml 文件中,如下

所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?xml version="1.0" encoding="UTF-8"?>
<root>
<numbers>
<!--
数字信息
-->
[
[1, 82, 65535],
[20, 90, 13],
[26, 809, 1024]
]
</numbers>
</root>

Solution: Write Excel Data to XML III, 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-28 21:13:00
# @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(list_content):
'''
将 dict 格式数据写入 xml 文件
'''
xml_doc = minidom.Document()
root = xml_doc.createElement('root')
xml_doc.appendChild(root)
numbers = xml_doc.createElement('numbers')
root.appendChild(numbers)
comment = xml_doc.createComment('数字信息')
numbers.appendChild(comment)
content = xml_doc.createTextNode(str(list_content))
numbers.appendChild(content)
with open('numbers.xml', 'wb') as f:
f.write(xml_doc.toprettyxml(encoding='utf-8'))
def load_data_as_list(f_path):
'''
从 Excel 文件中读取数据,以 list 格式返回
'''
workbook = open_workbook(f_path)
list_content = []
sheet = workbook.sheet_by_name('numbers')
for row in xrange(sheet.nrows):
list_content.append(sheet.row_values(row)[:])
return list_content
def main():
f_path = 'numbers.xlsx'
list_content = load_data_as_list(f_path)
write_data_to_xml(list_content)
if __name__ == '__main__':
main()

第 0018题相似。

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