Added Pie Charts of TCE/TCO2E to ShopfloorEnergycategory Excel Exporter
parent
b9c8352b00
commit
d6f24b6e8d
|
@ -363,13 +363,157 @@ def generate_excel(report,
|
||||||
ws.row_dimensions[i].height = 0.1
|
ws.row_dimensions[i].height = 0.1
|
||||||
|
|
||||||
####################################################################################################################
|
####################################################################################################################
|
||||||
# Fourth: Detailed Data
|
# Third: Ton of Standard Coal(TCE) by Energy Category
|
||||||
|
# current_row_number: title
|
||||||
|
# current_row_number + 1: table title
|
||||||
|
# current_row_number + 1 + ca_len table_data
|
||||||
|
# Total: 2 + ca_len rows
|
||||||
|
####################################################################################################################
|
||||||
|
current_row_number = 19
|
||||||
|
has_kgce_data_flag = True
|
||||||
|
|
||||||
|
if "subtotals_in_kgce" not in reporting_period_data.keys() or \
|
||||||
|
reporting_period_data['subtotals_in_kgce'] is None or \
|
||||||
|
len(reporting_period_data['subtotals_in_kgce']) == 0:
|
||||||
|
has_kgce_data_flag = False
|
||||||
|
|
||||||
|
if has_kgce_data_flag:
|
||||||
|
ws['B' + str(current_row_number)].font = title_font
|
||||||
|
ws['B' + str(current_row_number)] = name + ' ' + 'Ton of Standard Coal(TCE) by Energy Category'
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
table_start_row_number = current_row_number
|
||||||
|
|
||||||
|
ws.row_dimensions[current_row_number].height = 60
|
||||||
|
ws['B' + str(current_row_number)].fill = table_fill
|
||||||
|
ws['B' + str(current_row_number)].font = name_font
|
||||||
|
ws['B' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['B' + str(current_row_number)].border = f_border
|
||||||
|
|
||||||
|
ws['C' + str(current_row_number)].fill = table_fill
|
||||||
|
ws['C' + str(current_row_number)].font = name_font
|
||||||
|
ws['C' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['C' + str(current_row_number)].border = f_border
|
||||||
|
ws['C' + str(current_row_number)] = 'Ton of Standard Coal(TCE) by Energy Category'
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
|
||||||
|
ca_len = len(reporting_period_data['names'])
|
||||||
|
|
||||||
|
for i in range(0, ca_len):
|
||||||
|
ws['B' + str(current_row_number)].font = title_font
|
||||||
|
ws['B' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['B' + str(current_row_number)] = reporting_period_data['names'][i]
|
||||||
|
ws['B' + str(current_row_number)].border = f_border
|
||||||
|
|
||||||
|
ws['C' + str(current_row_number)].font = title_font
|
||||||
|
ws['C' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['C' + str(current_row_number)].border = f_border
|
||||||
|
ws['C' + str(current_row_number)] = round(reporting_period_data['subtotals_in_kgce'][i] / 1000, 3)
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
|
||||||
|
table_end_row_number = current_row_number - 1
|
||||||
|
|
||||||
|
pie = PieChart()
|
||||||
|
pie.title = name + ' ' + ws.cell(column=3, row=table_start_row_number).value
|
||||||
|
labels = Reference(ws, min_col=2, min_row=table_start_row_number+1, max_row=table_end_row_number)
|
||||||
|
pie_data = Reference(ws, min_col=3, min_row=table_start_row_number, max_row=table_end_row_number)
|
||||||
|
pie.add_data(pie_data, titles_from_data=True)
|
||||||
|
pie.set_categories(labels)
|
||||||
|
pie.height = 7.25
|
||||||
|
pie.width = 9
|
||||||
|
s1 = pie.series[0]
|
||||||
|
s1.dLbls = DataLabelList()
|
||||||
|
s1.dLbls.showCatName = False
|
||||||
|
s1.dLbls.showVal = True
|
||||||
|
s1.dLbls.showPercent = True
|
||||||
|
table_cell = 'D' + str(table_start_row_number)
|
||||||
|
ws.add_chart(pie, table_cell)
|
||||||
|
|
||||||
|
if ca_len < 4:
|
||||||
|
current_row_number = current_row_number - ca_len + 4
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
####################################################################################################################
|
||||||
|
# Fourth: Ton of Carbon Dioxide Emissions(TCO2E) by Energy Category
|
||||||
|
# current_row_number: title
|
||||||
|
# current_row_number + 1: table title
|
||||||
|
# current_row_number + 1 + ca_len table_data
|
||||||
|
# Total: 2 + ca_len rows
|
||||||
|
####################################################################################################################
|
||||||
|
has_kgco2e_data_flag = True
|
||||||
|
|
||||||
|
if "subtotals_in_kgco2e" not in reporting_period_data.keys() or \
|
||||||
|
reporting_period_data['subtotals_in_kgco2e'] is None or \
|
||||||
|
len(reporting_period_data['subtotals_in_kgco2e']) == 0:
|
||||||
|
has_kgco2e_data_flag = False
|
||||||
|
|
||||||
|
if has_kgco2e_data_flag:
|
||||||
|
ws['B' + str(current_row_number)].font = title_font
|
||||||
|
ws['B' + str(current_row_number)] = name + ' ' + 'Ton of Carbon Dioxide Emissions(TCO2E) by Energy Category'
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
table_start_row_number = current_row_number
|
||||||
|
|
||||||
|
ws.row_dimensions[current_row_number].height = 75
|
||||||
|
ws['B' + str(current_row_number)].fill = table_fill
|
||||||
|
ws['B' + str(current_row_number)].font = name_font
|
||||||
|
ws['B' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['B' + str(current_row_number)].border = f_border
|
||||||
|
|
||||||
|
ws['C' + str(current_row_number)].fill = table_fill
|
||||||
|
ws['C' + str(current_row_number)].font = name_font
|
||||||
|
ws['C' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['C' + str(current_row_number)].border = f_border
|
||||||
|
ws['C' + str(current_row_number)] = 'Ton of Carbon Dioxide Emissions(TCO2E) by Energy Category'
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
|
||||||
|
ca_len = len(reporting_period_data['names'])
|
||||||
|
|
||||||
|
for i in range(0, ca_len):
|
||||||
|
ws['B' + str(current_row_number)].font = title_font
|
||||||
|
ws['B' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['B' + str(current_row_number)] = reporting_period_data['names'][i]
|
||||||
|
ws['B' + str(current_row_number)].border = f_border
|
||||||
|
|
||||||
|
ws['C' + str(current_row_number)].font = title_font
|
||||||
|
ws['C' + str(current_row_number)].alignment = c_c_alignment
|
||||||
|
ws['C' + str(current_row_number)].border = f_border
|
||||||
|
ws['C' + str(current_row_number)] = round(reporting_period_data['subtotals_in_kgco2e'][i] / 1000, 3)
|
||||||
|
current_row_number += 1
|
||||||
|
|
||||||
|
table_end_row_number = current_row_number - 1
|
||||||
|
|
||||||
|
pie = PieChart()
|
||||||
|
pie.title = name + ' ' + ws.cell(column=3, row=table_start_row_number).value
|
||||||
|
labels = Reference(ws, min_col=2, min_row=table_start_row_number + 1, max_row=table_end_row_number)
|
||||||
|
pie_data = Reference(ws, min_col=3, min_row=table_start_row_number, max_row=table_end_row_number)
|
||||||
|
pie.add_data(pie_data, titles_from_data=True)
|
||||||
|
pie.set_categories(labels)
|
||||||
|
pie.height = 7.75
|
||||||
|
pie.width = 9
|
||||||
|
s1 = pie.series[0]
|
||||||
|
s1.dLbls = DataLabelList()
|
||||||
|
s1.dLbls.showCatName = False
|
||||||
|
s1.dLbls.showVal = True
|
||||||
|
s1.dLbls.showPercent = True
|
||||||
|
table_cell = 'D' + str(table_start_row_number)
|
||||||
|
ws.add_chart(pie, table_cell)
|
||||||
|
|
||||||
|
if ca_len < 4:
|
||||||
|
current_row_number = current_row_number - ca_len + 4
|
||||||
|
|
||||||
|
current_row_number += 1
|
||||||
|
|
||||||
|
####################################################################################################################
|
||||||
|
# Fifth: Detailed Data
|
||||||
# current_row_number: title
|
# current_row_number: title
|
||||||
# current_row_number+1 ~ current_row_number+1+ca_len*6-1: line
|
# current_row_number+1 ~ current_row_number+1+ca_len*6-1: line
|
||||||
# current_row_number+1+ca_len*6: table title
|
# current_row_number+1+ca_len*6: table title
|
||||||
# current_row_number+1+ca_len*6~: table_data
|
# current_row_number+1+ca_len*6~: table_data
|
||||||
####################################################################################################################
|
####################################################################################################################
|
||||||
current_row_number = 19
|
|
||||||
reporting_period_data = report['reporting_period']
|
reporting_period_data = report['reporting_period']
|
||||||
times = reporting_period_data['timestamps']
|
times = reporting_period_data['timestamps']
|
||||||
has_detail_data_flag = True
|
has_detail_data_flag = True
|
||||||
|
|
Loading…
Reference in New Issue