我们先来看一下效果(简单的写了一个):

原理:将post请求的代码数据写入了服务器的一个文件,然后用服务器的python编译器执行返回结果

实现代码:

#flaskrun.py

# -*- coding: utf-8 -*-

# __author__="ZJL"

from flask import Flask

from flask import request

from flask import Response

import json

import zxby

app = Flask(__name__)

def Response_headers(content):

resp = Response(content)

resp.headers['Access-Control-Allow-Origin'] = '*'

return resp

@app.route('/')

def hello_world():

return Response_headers('hello world!!!')

@app.route('/run', methods=['POST'])

def run():

if request.method == 'POST' and request.form['code']:

code = request.form['code']

print(code)

jsondata = zxby.main(code)

return Response_headers(str(jsondata))

@app.errorhandler(403)

def page_not_found(error):

content = json.dumps({"error_code": "403"})

resp = Response_headers(content)

return resp

@app.errorhandler(404)

def page_not_found(error):

content = json.dumps({"error_code": "404"})

resp = Response_headers(content)

return resp

@app.errorhandler(400)

def page_not_found(error):

content = json.dumps({"error_code": "400"})

resp = Response_headers(content)

return resp

@app.errorhandler(405)

def page_not_found(error):

content = json.dumps({"error_code": "405"})

resp = Response_headers(content)

return resp

@app.errorhandler(410)

def page_not_found(error):

content = json.dumps({"error_code": "410"})

resp = Response_headers(content)

return resp

@app.errorhandler(500)

def page_not_found(error):

content = json.dumps({"error_code": "500"})

resp = Response_headers(content)

return resp

if __name__ == '__main__':

app.run(debug=True)

#zxby.py

# -*- coding: utf-8 -*-

# __author__="ZJL"

import os, sys, subprocess, tempfile, time

# 创建临时文件夹,返回临时文件夹路径

TempFile = tempfile.mkdtemp(suffix='_test', prefix='python_')

# 文件名

FileNum = int(time.time() * 1000)

# python编译器位置

EXEC = sys.executable

# 获取python版本

def get_version():

v = sys.version_info

version = "python %s.%s" % (v.major, v.minor)

return version

# 获得py文件名

def get_pyname():

global FileNum

return 'test_%d' % FileNum

# 接收代码写入文件

def write_file(pyname, code):

fpath = os.path.join(TempFile, '%s.py' % pyname)

with open(fpath, 'w', encoding='utf-8') as f:

f.write(code)

print('file path: %s' % fpath)

return fpath

# 编码

def decode(s):

try:

return s.decode('utf-8')

except UnicodeDecodeError:

return s.decode('gbk')

# 主执行函数

def main(code):

r = dict()

r["version"] = get_version()

pyname = get_pyname()

fpath = write_file(pyname, code)

try:

# subprocess.check_output 是 父进程等待子进程完成,返回子进程向标准输出的输出结果

# stderr是标准输出的类型

outdata = decode(subprocess.check_output([EXEC, fpath], stderr=subprocess.STDOUT, timeout=5))

except subprocess.CalledProcessError as e:

# e.output是错误信息标准输出

# 错误返回的数据

r["code"] = 'Error'

r["output"] = decode(e.output)

return r

else:

# 成功返回的数据

r['output'] = outdata

r["code"] = "Success"

return r

finally:

# 删除文件(其实不用删除临时文件会自动删除)

try:

os.remove(fpath)

except Exception as e:

exit(1)

if __name__ == '__main__':

code = "print(11);print(22)"

print(main(code))

运行app.run()方法,通过post提交代码,就ok了。我们可以对输出结过做进一步的处理,我这只是为了解一下原理,就没继续了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

python在线编辑器编译excel_python在线编译器的简单原理及简单实现代码相关推荐

  1. python在线编译-python在线编译器的简单原理及简单实现代码

    我们先来看一下效果(简单的写了一个): 原理:将post请求的代码数据写入了服务器的一个文件,然后用服务器的python编译器执行返回结果 实现代码: #flaskrun.py # -*- codin ...

  2. 在线python编程编译器-python在线编译器的简单原理及简单实现代码

    我们先来看一下效果(简单的写了一个): 原理:将post请求的代码数据写入了服务器的一个文件,然后用服务器的python编译器执行返回结果 实现代码: #flaskrun.py # -*- codin ...

  3. python下载图片插入excel_Python向Excel中插入图片的简单实现方法

    本文实例讲述了Python向Excel中插入图片的简单实现方法.分享给大家供大家参考,具体如下: 使用Python向Excel文件中插入图片,这个功能之前学习xlwt的时候通过xlwt模块实现过.那时 ...

  4. YAML、YML在线编辑器(格式化校验)解析工具-toolfk.com

    本文要推荐的[ToolFk]是一款程序员经常使用的线上免费测试工具箱,ToolFk 特色是专注于程序员日常的开发工具,不用安装任何软件,只要把内容贴上按一个执行按钮,就能获取到想要的内容结果.Tool ...

  5. 前端代码在线编辑器:codepen、codesandbox

    文章目录 单文件在线编辑器 项目级在线编辑器 推荐两个前端代码在线编辑器 单文件在线编辑器:https://codepen.io/pen/ 项目级在线编辑器:https://codesandbox.i ...

  6. python在线编辑器-在线编译或编辑Python的5个最佳工具

    离线Python编辑器和编译器都具有许多功能,但是在线编译器通常在功能上受到限制,并试图满足特定需求而不是满足所有需求,其中在线编译大多数是免费的,所以也受到开发者的热爱. 在本文中,我们将浏览各种狂 ...

  7. python在线编辑器-在线python编辑器

    广告关闭 2017年12月,云+社区对外发布,从最开始的技术博客到现在拥有多个社区产品.未来,我们一起乘风破浪,创造无限可能. windows下python的ide选择:http:blog.csdn. ...

  8. html代码编辑器sp,在线HTML编译,文本关键字高亮显示,富文本编辑实现大概思路...

    ????最近被安排做了一个HTML在线编译功能,也利用这个机会对HTML在线编译,关键字高亮,富文本编辑器等的实现做了一些比较表面的研究,做简要记录,以便再次遇到作为参考. ????在线HTML编译 ...

  9. Google推出了牛逼的Python在线编辑器,以后协同项目代码就省心了

    Google推出了牛逼的Python在线编辑器,以后协同项目代码就省心了,环境配置对于大多数人来说都是拦路虎,我们小白往往不知道: 怎么正确的安装 不知道选择什么 怎么安装常用的第三方库 ... Go ...

最新文章

  1. 裸奔的支付X聊天,你还敢用吗?
  2. 定义一个DOG类(Java)
  3. 《卫生信息基本数据集编制规范》等23项行业标准的通告
  4. 【Python3爬虫】为什么你的博客没人看呢?
  5. 《scikit-learn》SVM(二)数据不均衡
  6. android5.0+art模式,Android 5.0有哪些变化
  7. android去掉锁屏界面,android怎么去掉锁屏界面
  8. KND数控系统PLC开发环境
  9. 三亚游—温暖的寒冬、蔚蓝的海和安九拉
  10. 图像处理 灰度变换与空间滤波
  11. 利用存儲過程進行簡繁體轉換
  12. VVC/VTM:代码学习——CIIP详细过程
  13. android handle 用法
  14. 怎么开淘宝网店?淘宝网开店流程图解,淘宝开店教程!
  15. 当前电子鼻系统数据处理中常用的模式识别技术
  16. 嵌入式在军工卫星应用手持终端领域的应用
  17. 微信聊天记录能恢复吗?值得试手的2个方法推荐
  18. 杭州java好找工作吗_【java】我是学java的应届毕业生,来杭州一个多星期了,还没找到工作,能指点...
  19. oracle12c安装卡住_oracle12c安装,oracle12c安装第一步卡死
  20. CocosCreator之A星寻路

热门文章

  1. 软件熵:软件开发中推倒重来的过程就是软件熵不断增加的过程
  2. 不同浏览器对URL最大长度的限制
  3. 部门工作中的“求同存异”法则
  4. 《你不知道的Javascript--上卷 学习总结》(原型)
  5. js禁止用户右键等操作
  6. SAP R3 FI 上线 顾问设置教程(一)
  7. (LeetCode 153)Find Minimum in Rotated Sorted Array
  8. pcre库文件的安装
  9. Windows 7使用MMC管理控制台“远程桌面”功能【转载】
  10. 什么时候可以全面升级鸿蒙系统,华为已做好全面升级准备,鸿蒙系统将替换底层安卓系统...