-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemplate_xls_fast.py
58 lines (56 loc) · 1.9 KB
/
template_xls_fast.py
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
#!/usr/bin/python3
# -*- coding: utf-8 -*-
# pip3 install xlutils
import xlrd
import xlwt
from xlutils.copy import copy
import os
def saveData(dataset_list, output_file):
output_file = "{}.xls".format(output_file) # this will be xls file name
fieldnames = ["Header 1", "Header 2", "Header 3", "Header 4"] # change your header list here
wb = xlwt.Workbook(encoding="UTF-8")
ws = wb.add_sheet("Sheet 1")
if os.path.exists(output_file):
# old file, get last untouched row and start writing data
while True:
try:
rb = xlrd.open_workbook(
output_file, formatting_info=True, on_demand=False)
sht = rb.sheet_by_index(0)
lastRows = sht.nrows
wb = copy(rb)
sheet = wb.get_sheet(0)
pos = 0
for dataset in dataset_list:
for data in dataset:
sheet.write(lastRows, pos, data)
pos += 1
pos = 0
lastRows += 1
wb.save(output_file)
break
except OSError:
pass
else:
# new file, create the headers
pos = 0
for fieldname in fieldnames:
ws.write(0, pos, fieldname)
pos += 1
# now saving rows of data
pos = 0
lastRows = 1
for dataset in dataset_list:
for data in dataset:
ws.write(lastRows, pos, data)
pos += 1
pos = 0
lastRows += 1
wb.save(output_file)
if __name__ == "__main__":
data = ["Cell data 1", "Cell data 2", "Cell data 3", "Cell data 4"]
data2 = ["Cell data 5", "Cell data 6", "Cell data 7", "Cell data 8"]
data_collection = []
data_collection.append(data)
data_collection.append(data2)
saveData(data_collection, "my_sheet")