2022年 11月 7日

python 在线编译器

  1. import os, sys, subprocess, time
  2. class AdvanceQuery(object):
  3. def __init__(self):
  4. self.TempFile = "media/advance_query"
  5. # 文件名
  6. self.FileNum = int(time.time() * 1000)
  7. # python编译器位置
  8. self.EXEC = sys.executable
  9. # 获取python版本
  10. def get_version(self):
  11. v = sys.version_info
  12. version = "python %s.%s" % (v.major, v.minor)
  13. return version
  14. # 获得py文件名
  15. def get_pyname(self):
  16. return '%d' % self.FileNum
  17. # 接收代码写入文件
  18. def write_file(self, pyname, code):
  19. if not os.path.exists(self.TempFile):
  20. os.mkdir(self.TempFile)
  21. fpath = os.path.join(self.TempFile, '%s.py' % pyname)
  22. with open(fpath, 'w', encoding='utf-8') as f:
  23. f.write(code)
  24. # print('file path: %s' % fpath)
  25. return fpath
  26. # 编码
  27. def decode(self, s):
  28. try:
  29. return s.decode('utf-8')
  30. except UnicodeDecodeError:
  31. return s.decode('gbk')
  32. def query_main(self, code):
  33. r = dict()
  34. r["version"] = self.get_version()
  35. pyname = self.get_pyname()
  36. fpath = self.write_file(pyname, code)
  37. try:
  38. # subprocess.check_output 是 父进程等待子进程完成,返回子进程向标准输出的输出结果
  39. # stderr是标准输出的类型
  40. """subprocess.check_output(args, *, stdin=None, stderr=None, shell=False, universal_newlines=False)
  41. 父进程直接创建子进程执行程序,以字符串的形式返回子进程的输出。"""
  42. outdata = self.decode(subprocess.check_output([self.EXEC, fpath], stderr=subprocess.STDOUT, timeout=5))
  43. except subprocess.CalledProcessError as e:
  44. # e.output是错误信息标准输出
  45. # 错误返回的数据
  46. r["code"] = 'Error'
  47. r["output"] = self.decode(e.output)
  48. return r
  49. else:
  50. # 成功返回的数据
  51. r['output'] = outdata
  52. r["code"] = "Success"
  53. return r
  54. finally:
  55. # 删除文件(其实不用删除临时文件会自动删除)
  56. try:
  57. os.remove(fpath)
  58. except Exception as e:
  59. exit(1)
  60. # 显示csv列表
  61. def csv_list(self):
  62. path = os.getcwd()
  63. alist = []
  64. for i in os.listdir(os.path.join(path, "csv")):
  65. # print(os.path.join(path, "csv"))
  66. if i.split(".")[1] == "csv":
  67. alist.append(i)
  68. data = {"csv_list": alist}
  69. return data
  70. # 根据csv返回相应语句显示
  71. def show_statement(self, st):
  72. if st:
  73. data = 'import pandas as pd\ndp = pd.read_csv("csv/%s")' % st
  74. return data