python代码运行助手是能在网页上运行python语言的工具。因为python的运行环境在很多教程里都是用dos的,黑乎乎的界面看的有点简陋,所以出了这python代码运行助手,作为ide。

实际上,python代码运行助手界面只能算及格分,如果要找ide,推荐使用jupyter。jupyter被集成到ANACONDA里,只要安装了anacoda就能使用了。

1、要打开这运行助手首先要下载一个learning.py,如果找不到可以复制如下代码另存为“learning.py”,编辑器用sublime、或者notepad++。

#!/usr/bin/env python3

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

r'''

learning.py

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'

Learning Python

Run

']

if method == 'GET' and path == '/env':

start_response('200 OK', [('Content-Type', 'text/html')])

L = [b'

ENV']

for k, v in environ.items():

p = '

%s = %s' % (k, str(v))

L.append(p.encode('utf-8'))

L.append(b'')

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()

2、再用一个记事本写如下的代码:

@echo off

python learning.py

pause

另存为‘运行.bat'

3、把“运行.bat”和“learning.py”放到同一目录下。

4、双击运行“运行.bat",之后会弹出黑色的dos窗口,这个窗口不要关闭。

5、输入网址对应的网址和端口,整个过程就完成了。

知识点扩展:

Python在线运行代码助手

#!/usr/bin/env python3

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

r'''

learning.py

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'

Learning Python

Run

']

if method == 'GET' and path == '/env':

start_response('200 OK','text/html')])

L = [b'

ENV']

for k,v in environ.items():

p = '

%s = %s' % (k,str(v))

L.append(p.encode('utf-8'))

L.append(b'')

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','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','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','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()

到此这篇关于python如何使用代码运行助手的文章就介绍到这了,更多相关python代码运行助手用法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!·

origin python控制台怎么用_python如何使用代码运行助手相关推荐

  1. origin python控制台怎么用_python代码运行助手如何使用

    python代码运行助手是能在网页上运行python语言的工具.因为python的运行环境在很多教程里都是用dos的,黑乎乎的界面看的有点简陋,所以出了这python代码运行助手,作为ide. 实际上 ...

  2. python代码运行助手是什么业务_python代码运行助手怎么使用()

    python代码运行助手怎么使用 #/usr/bin/env python3 # -*- coding: utf-8 -*- r''' learning.py A Python 3 tutorial  ...

  3. python代码运行助手是什么业务_Python代码运行助手

    Python代码运行助手可以让你在线输入Python代码,然后通过本机运行的一个Python脚本来执行代码.原理如下: 在网页输入代码: 点击Run按钮,代码被发送到本机正在运行的Python代码运行 ...

  4. Python控制台英汉-汉英电子词典(代码分享)

    Python控制台英汉-汉英电子词典 By qianghaohao(CodeNutter) 用python实现了下控制台电子词典,数据来自有道,通过向有道发送http表单数据, 然后将服务器返回的js ...

  5. python释放变量内存_python解释器安装,运行python程序的方式及程序运行的步骤,变量与自动的内存管理...

    一.python解释器安装 ps: 注意设置环境变量(文件是操作系统的概念,操作系统优先在当前文件夹找,找不到就到环境变量path找) python解释器不兼容 解释器下载官网:http://pyth ...

  6. python——关于“霍兰德人格分析雷达图”代码运行错误解决

    问题描述: 嵩天老师课上代码运行时出现两个问题: 1.无Qt平台插件错误(解决了很久):This application failed to start because no Qt platform ...

  7. python控制台不能输入_python实现在控制台输入密码不显示的方法

    本文实例讲述了python实现在控制台输入密码不显示的方法.分享给大家供大家参考.具体实现方法如下: import console; namespace console{ //控制台读取密码,并显示星 ...

  8. python控制台进度条_python在控制台输出进度条的方法

    本文实例讲述了python在控制台输出进度条的方法.分享给大家供大家参考.具体实现方法如下: 进度条效果如下所示: |#############################------------ ...

  9. origin python控制台怎么用_如何在标准python控制台中访问BPY?BPY是python的混合器...

    获取搅拌机源代码:cd ~/src # or what you prefer git clone http://git.blender.org/blender.git cd blender git s ...

最新文章

  1. LeetCode简单题之矩阵对角线元素的和
  2. 薛XX后代的IQ CSU1597【循环节】或【快速幂】
  3. Pytorch(1)-内置/自己设计的损失函数使用
  4. 【IEnumerable】扩展方法的使用 C#
  5. 目录:关于【稳定性建设之道】大纲速览
  6. 计算机Excel应用案例,Excel VBA在Office中的应用案例
  7. SCADA电力系统基础业务知识
  8. 全志V3S学习笔记(二)PCF8563
  9. 【阿里云短信】开通使用
  10. 征途mysql启动不了_征途单机版架设中场景服务器启动失败?这是为什么?
  11. android edittext禁止输入特殊字符,Android edittext 禁止输入特殊字符/或者表情符的方案...
  12. 2022年1月语音合成(TTS)和语音识别(ASR)论文月报
  13. JAVA定义一个树形的结构_Java自定义树形结构
  14. 机器人系统设计与制作:Python语言实现2.4 用LibreCAD生成机器人的二维CAD图
  15. 116. 飞行员兄弟 Java题解
  16. 在oracle你如何加供应商,cognos特定于供应商的函数如何添加oracle函数
  17. 调研:“淘宝村”、“网店村”是如何发家的?
  18. 手工搭建基于ABP的框架(3) - 登录,权限控制与日志
  19. 红米Note10Pro安装twrp教程
  20. 第八届开源中国开源世界高峰论坛--开放.互联.移动的新时代

热门文章

  1. 《Rumor Detection By Exploiting User Credibility Information,Attention and Multi-task Learnning 》解读
  2. 十年后,程序员还会有今天的收入吗?
  3. Midjourney V5横空出世:画出完美中国情侣 逼真得令人毛骨悚然
  4. 阴阳师服务器维护2.11,[公告] 《阴阳师》2月11日正式服维护详情
  5. HAR(HTTP Archive)规范
  6. 无限法则服务器选择吗,开发者Q&A—DX12专题5.18.2019
  7. 8条标准背后的“隐情”
  8. 36万美元套利!3 个步骤揭秘黑客DeFi闪电贷操盘全过程
  9. Creator 3.x 入门修炼指南!精简优化版
  10. 人均收割百万点击,B站这些黑马UP主内容亮点在何处?