forked from ma6174/acmjudger
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathget_code.py
63 lines (60 loc) · 1.65 KB
/
get_code.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
59
60
61
#!/usr/bin/env python
# coding=utf-8
def get_code(solution_id, problem_id, pro_lang):
'''从数据库获取代码并写入work目录下对应的文件'''
file_name = {
"gcc": "main.c",
"g++": "main.cpp",
"java": "Main.java",
'ruby': "main.rb",
"perl": "main.pl",
"pascal": "main.pas",
"go": "main.go",
"lua": "main.lua",
'python2': 'main.py',
'python3': 'main.py',
"haskell": "main.hs"
}
select_code_sql = "#####"
feh = run_sql(select_code_sql)
if feh is not None:
try:
code = feh[0][0]
except:
logging.error("1 cannot get code of runid %s" % solution_id)
return False
else:
logging.error("2 cannot get code of runid %s" % solution_id)
return False
try:
work_path = os.path.join(config.work_dir, str(solution_id))
low_level()
os.mkdir(work_path)
except OSError as e:
if str(e).find("exist") > 0: # 文件夹已经存在
pass
else:
logging.error(e)
return False
try:
real_path = os.path.join(
config.work_dir,
str(solution_id),
file_name[pro_lang])
except KeyError as e:
logging.error(e)
return False
try:
low_level()
f = codecs.open(real_path, 'w')
try:
f.write(code)
except:
logging.error("%s not write code to file" % solution_id)
f.close()
return False
f.close()
except OSError as e:
logging.error(e)
return False
return True