1 Star 0 Fork 51

shuliang/Ark-workload

forked from xliu/Ark-workload 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
pgo2excel.py 4.72 KB
一键复制 编辑 原始数据 按行查看 历史
import os
from openpyxl import load_workbook,Workbook
import sys
ark_js_vm=""
arguments = sys.argv
run_count = 1
for i in range(len(arguments)):
if arguments[i] == '--case-dir':
pgo2path=arguments[i+1]
Date = pgo2path[pgo2path.rfind('/') + 1:]
if arguments[i] == '--run-count':
run_count = int(arguments[i+1])
if arguments[i] == '--run-case':
name=arguments[i+1]
if arguments[i] == '--ark_js_vm':
ark_js_vm=arguments[i+1]
if ark_js_vm=="":
print("please pass in the ark_js_vm path")
sys.exit()
def variable_exists(var_name):
try:
exec(var_name)
except NameError:
return False
else:
return True
if not variable_exists("pgo2path"):
sys.exit()
def runCmd(cmd):
result = os.popen(cmd).read()
print(cmd)
print(result+"\n\n")
with open(f"pgo_{Date}_log.txt", "a") as file:
file.writelines(cmd+"\n")
with open(f"pgo_{Date}_log.txt", "a") as file:
file.writelines(result+"\n")
return result
def is_excel_sheet_empty(file_path, sheet_name):
try:
workbook = load_workbook(filename=file_path)
sheet = workbook[sheet_name]
if sheet.max_row == 1 and sheet.max_column == 1 and sheet.cell(row=1, column=1).value is None:
return True
else:
return False
except Exception as e:
print(f"An error occurred: {str(e)}")
return None
def is_excel_file_exists(file_path):
try:
workbook = load_workbook(filename=file_path)
return True
except FileNotFoundError:
return False
def run():
print("---------------------------------------")
if not is_excel_file_exists(f'pgo_data_{Date}.xlsx'):
workbook = Workbook()
sheet = workbook.active
data = ["case"]
for i in range(run_count):
data.append(f"data{i}")
data.append(f"average")
sheet.append(data)
sheet2 = workbook.create_sheet(title="Sheet2")
sheet2['A1'] = 'case'
sheet2['B1'] = 'average'
workbook.save(f'pgo_data_{Date}.xlsx')
workbook = load_workbook(f'pgo_data_{Date}.xlsx')
sheet = workbook['Sheet']
sheet2 = workbook['Sheet2']
with open(f"pgo_{Date}_error.txt", "w") as file:
pass
print(name)
test_data = {}
with open(f"pgo_{Date}_log.txt", "a") as file:
file.writelines(name+"\n")
with open(f"pgo_{Date}_error.txt", "a") as file:
file.writelines(name+"\n")
for i in range(run_count):
cmd = f"cd {pgo2path} && {ark_js_vm} --entry-point={name} --aot-file=./{name} {name}.abc"
result = runCmd(cmd)
if "error" in result or "Signal" in result or "TypeError" in result or "RangeError" in result:
with open(f"pgo_{Date}_error.txt", "a") as file:
file.writelines(f"{result}\n")
print(f"result error: {result}")
continue
result = result.split("\n")
print(f"result: {result}")
for value in result:
data = value
if " ms = " in value:
value=value.replace(":","")
value = value.split(" ms = ")
elif ": \t" in value and "ms" in value:
value=value.replace(" : ","")
value=value.replace(": ","")
value = value.split("\t")
elif ": " in value and "ms" in value:
value=value.replace(": ","\t")
value=value.replace(": ","")
value = value.split("\t")
elif " : " in value and "ms" in value:
value=value.replace(" : ","\t")
value = value.split("\t")
elif ":" in value and "ms" in value:
value=value.replace(":","")
value = value.split("\t")
elif " - " in value or "Splay:" in value:
value=value.replace(":","")
value = value.split("\t")
elif "usec = " in value:
value = value.split(": usec = ")
else:
continue
with open(f"data_{Date}.txt", "a") as file:
file.writelines(data+"\n")
if not value[0] in test_data:
test_data[value[0]] = []
test_data[value[0]].append(value[1])
print(test_data)
for itme in test_data:
data = []
data.append(itme)
sum = 0
for value in test_data[itme]:
data.append(round(float(value),3))
sum += round(float(value),3)
average=round(sum/len(test_data[itme]),3)
data.append(average)
sheet.append(data)
sheet2.append([itme,average])
workbook.save(f'pgo_data_{Date}.xlsx')
print("---------------------------------------\n")
run()
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
TypeScript
1
https://gitee.com/qishui7/ark-workload.git
[email protected]:qishui7/ark-workload.git
qishui7
ark-workload
Ark-workload
master

搜索帮助