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
| import os import json import pandas as pd import pandas as pd import numpy as np from openpyxl.utils import get_column_letter from pandas import ExcelWriter from datetime import datetime
def to_excel_auto_column_weight(df: pd.DataFrame, writer: ExcelWriter, sheet_name="Shee1"): """DataFrame保存为excel并自动设置列宽""" df.to_excel(writer, sheet_name=sheet_name, index=False) column_widths = ( df.columns.to_series().apply(lambda x: len(str(x).encode('gbk'))).values ) max_widths = ( df.astype(str).applymap(lambda x: len(str(x).encode('gbk'))).agg(max).values ) widths = np.max([column_widths, max_widths], axis=0) worksheet = writer.sheets[sheet_name] for i, width in enumerate(widths, 1): worksheet.column_dimensions[get_column_letter(i)].width = width + 2
DIR='./data/report'
header = ['PlanId', '测试板编号', 'IP地址', 'SN', '板子状态', '测试耗时', 'NovaOs版本', '失败模块', '测试结果']
DataList = []
for root, dirs, files in os.walk(DIR): for name in dirs: sub_dir = os.path.join(root, name) file = sub_dir + '/' + "result.json" if os.path.exists(file): with open(file, 'r') as f: data = json.load(f) serial = data['board_results'][-1]['board']['serial'] ip = data['board_results'][-1]['board']['ip'] sn = data['board_results'][-1]['board']['sn'] board_status = data['board_results'][-1]['board_status'] test_duration = data['board_results'][-1]['test_duration'] test_result = data['board_results'][-1]['test_result'] version = data['board_results'][-1]['version'] failed_features = data['board_results'][-1]['failed_features'] row=[name, serial, ip, sn, board_status, test_duration, version, failed_features, test_result] DataList.append(row) df = pd.DataFrame(DataList, columns=header)
df.style.set_properties(**{'text-align': 'center'}).set_table_styles([ dict(selector='th', props=[('text-align', 'center')])])
writer = pd.ExcelWriter('report.xlsx') for i in df['IP地址'].unique(): tmpData=df[df['IP地址'] == i] to_excel_auto_column_weight(tmpData, writer, i) writer.close()
now = datetime.now() time = now.strftime("%Y-%m-%d-%H_%M_%S")
os.system(f"sudo tar zcvf {time}_report.tar.gz /home/slt-racetrack-server/data/ ./report.xlsx") os.system("sudo rm -rf /home/slt-racetrack-server/data/*") os.system("sudo rm -rf ./report.xlsx")
|