Python在线运行代码助手


Posted in Python onJuly 15, 2016

Python代码运行助手可以让你在线输入Python代码,然后通过本机运行的一个Python脚本来执行代码。原理如下:

在网页输入代码:

Python在线运行代码助手

点击Run按钮,代码被发送到本机正在运行的Python代码运行助手;

Python代码运行助手将代码保存为临时文件,然后调用Python解释器执行代码;

网页显示代码执行结果:

Python在线运行代码助手

下载

点击右键,目标另存为:learning.py

备用下载地址:learning.py

完整代码:

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

r'''
learning.py

A Python 3 tutorial from http://www.liaoxuefeng.com

Usage:

python3 learning.py
'''

import sys

def check_version():
 v = sys.version_info
 if v.major == 3 and v.minor >= 4:
  return True
 print('Your current python is %d.%d. Please use Python 3.4.' % (v.major, v.minor))
 return False

if not check_version():
 exit(1)

import os, io, json, subprocess, tempfile
from urllib import parse
from wsgiref.simple_server import make_server

EXEC = sys.executable
PORT = 39093
HOST = 'local.liaoxuefeng.com:%d' % PORT
TEMP = tempfile.mkdtemp(suffix='_py', prefix='learn_python_')
INDEX = 0

def main():
 httpd = make_server('127.0.0.1', PORT, application)
 print('Ready for Python code on port %d...' % PORT)
 httpd.serve_forever()

def get_name():
 global INDEX
 INDEX = INDEX + 1
 return 'test_%d' % INDEX

def write_py(name, code):
 fpath = os.path.join(TEMP, '%s.py' % name)
 with open(fpath, 'w', encoding='utf-8') as f:
  f.write(code)
 print('Code wrote to: %s' % fpath)
 return fpath

def decode(s):
 try:
  return s.decode('utf-8')
 except UnicodeDecodeError:
  return s.decode('gbk')

def application(environ, start_response):
 host = environ.get('HTTP_HOST')
 method = environ.get('REQUEST_METHOD')
 path = environ.get('PATH_INFO')
 if method == 'GET' and path == '/':
  start_response('200 OK', [('Content-Type', 'text/html')])
  return [b'<html><head><title>Learning Python</title></head><body><form method="post" action="/run"><textarea name="code" style="width:90%;height: 600px"></textarea><p><button type="submit">Run</button></p></form></body></html>']
 if method == 'GET' and path == '/env':
  start_response('200 OK', [('Content-Type', 'text/html')])
  L = [b'<html><head><title>ENV</title></head><body>']
  for k, v in environ.items():
   p = '<p>%s = %s' % (k, str(v))
   L.append(p.encode('utf-8'))
  L.append(b'</html>')
  return L
 if host != HOST or method != 'POST' or path != '/run' or not environ.get('CONTENT_TYPE', '').lower().startswith('application/x-www-form-urlencoded'):
  start_response('400 Bad Request', [('Content-Type', 'application/json')])
  return [b'{"error":"bad_request"}']
 s = environ['wsgi.input'].read(int(environ['CONTENT_LENGTH']))
 qs = parse.parse_qs(s.decode('utf-8'))
 if not 'code' in qs:
  start_response('400 Bad Request', [('Content-Type', 'application/json')])
  return [b'{"error":"invalid_params"}']
 name = qs['name'][0] if 'name' in qs else get_name()
 code = qs['code'][0]
 headers = [('Content-Type', 'application/json')]
 origin = environ.get('HTTP_ORIGIN', '')
 if origin.find('.liaoxuefeng.com') == -1:
  start_response('400 Bad Request', [('Content-Type', 'application/json')])
  return [b'{"error":"invalid_origin"}']
 headers.append(('Access-Control-Allow-Origin', origin))
 start_response('200 OK', headers)
 r = dict()
 try:
  fpath = write_py(name, code)
  print('Execute: %s %s' % (EXEC, fpath))
  r['output'] = decode(subprocess.check_output([EXEC, fpath], stderr=subprocess.STDOUT, timeout=5))
 except subprocess.CalledProcessError as e:
  r = dict(error='Exception', output=decode(e.output))
 except subprocess.TimeoutExpired as e:
  r = dict(error='Timeout', output='执行超时')
 except subprocess.CalledProcessError as e:
  r = dict(error='Error', output='执行错误')
 print('Execute done.')
 return [json.dumps(r).encode('utf-8')]

if __name__ == '__main__':
 main()

运行

在存放learning.py的目录下运行命令:

C:\Users\michael\Downloads> python learning.py

如果看到Ready for Python code on port 39093...表示运行成功,不要关闭命令行窗口,最小化放到后台运行即可:

Python在线运行代码助手

试试效果

需要支持HTML5的浏览器:

IE >= 9
Firefox
Chrome
Sarafi

Python 相关文章推荐
Python中的文件和目录操作实现代码
Mar 13 Python
Python函数参数类型*、**的区别
Apr 11 Python
Python的Twisted框架中使用Deferred对象来管理回调函数
May 25 Python
pandas按若干个列的组合条件筛选数据的方法
Apr 11 Python
10 行Python 代码实现 AI 目标检测技术【推荐】
Jun 14 Python
python-序列解包(对可迭代元素的快速取值方法)
Aug 24 Python
python如何从文件读取数据及解析
Sep 19 Python
如何使用pandas读取txt文件中指定的列(有无标题)
Mar 05 Python
python实现梯度下降法
Mar 24 Python
Python常见反爬虫机制解决方案
Jun 01 Python
详解Pycharm与anaconda安装配置指南
Aug 25 Python
OpenCV-Python实现人脸磨皮算法
Jun 07 Python
python 实现网上商城,转账,存取款等功能的信用卡系统
Jul 15 #Python
python 性能提升的几种方法
Jul 15 #Python
浅谈Python 对象内存占用
Jul 15 #Python
python发送邮件功能实现代码
Jul 15 #Python
Python中列表和元组的使用方法和区别详解
Dec 30 #Python
Python中的变量和作用域详解
Jul 13 #Python
在Python中通过threading模块定义和调用线程的方法
Jul 12 #Python
You might like
如何开始收听短波广播
2021/03/01 无线电
造就帕卡马拉的帕卡斯是怎么被发现的
2021/03/03 咖啡文化
php的memcache类分享(memcache队列)
2014/03/26 PHP
php三种实现多线程类似的方法
2015/10/30 PHP
Symfony的安装和配置方法
2016/03/17 PHP
php 伪造HTTP_REFERER页面URL来源的三种方法
2016/09/22 PHP
JavaScript传递变量: 值传递?引用传递?
2011/02/22 Javascript
js判断一个字符串是否包含一个子串的方法
2015/01/26 Javascript
jQuery实现tab选项卡效果的方法
2015/07/08 Javascript
微信小程序 ES6Promise.all批量上传文件实现代码
2017/04/14 Javascript
Easyui ueditor 整合解决不能编辑的问题(推荐)
2017/06/25 Javascript
JS中通过url动态获取图片大小的方法小结(两种方法)
2018/10/31 Javascript
vue中各种通信传值方式总结
2019/02/14 Javascript
为vue项目自动设置请求状态的配置方法
2019/06/09 Javascript
js DOM的事件常见操作实例详解
2019/12/16 Javascript
微信小程序点击按钮动态切换input的disabled禁用/启用状态功能
2020/03/07 Javascript
原生js实现九宫格拖拽换位
2021/01/26 Javascript
[02:53]DOTA2亚洲邀请赛 NewBee战队巡礼
2015/02/03 DOTA
python抓取网页时字符集转换问题处理方案分享
2014/06/19 Python
详解用python自制微信机器人,定时发送天气预报
2019/03/25 Python
python安装numpy和pandas的方法步骤
2019/05/27 Python
python实现图片二值化及灰度处理方式
2019/12/07 Python
Python数据存储之 h5py详解
2019/12/26 Python
Tensorflow之MNIST CNN实现并保存、加载模型
2020/06/17 Python
Python使用lambda抛出异常实现方法解析
2020/08/20 Python
Django vue前后端分离整合过程解析
2020/11/20 Python
canvas版人体时钟的实现示例
2021/01/29 HTML / CSS
美国儿童珠宝在线零售商:Loveivy
2019/05/22 全球购物
什么是反射
2012/03/17 面试题
土木工程毕业生自荐信
2013/11/12 职场文书
酒店总经理助理岗位职责
2014/02/01 职场文书
2014政务公开实施方案
2014/02/19 职场文书
抗洪救灾感谢信
2015/01/22 职场文书
2015法院个人工作总结范文
2015/05/25 职场文书
2015元旦感言
2015/12/09 职场文书
Python 多线程处理任务实例
2021/11/07 Python