Python的解释器在linux上通常安装在/usr/bin/python,/usr/local/bin/python,/usr/local/bin/python等地方。Windows一般位于C:Python36,且一般需要设置PATH环境变量。
退出解释器:Linux上Control-D,Windows上Control-Z,统一的方式:quit()。
解释器的行编辑功能并不复杂。在Unix上,解释器可能已启用了GNU readline库,它增加了更多的交互编辑和历史记录功能。输入Control-P,如果发出哔哔声表示支持readline;见附录交互式输入编辑和历史替换https://docs.python.org/3/tutorial/interactive.html#tut-interacting。
解释器的操作有些像Unix Shell:当标准输入连接到tty设备时,它读取并以交互方式执行命令;当文件名参数或以文件作为标准输入设备时,它读取并执行文件中脚本。 启动解释器的第二个方法是python -c command [arg] …,执行command中的语句,等同于Shell的-c选项。因为Python语句通常会包括空格或其他shell的特殊字符是特殊的外壳,建议使 把command放在单引号中。注意因为缩进原因,开始的引号后面不能有空格。
# python3 -c "print('Hello')"Hello# $ python3 -c 'print("Hello")'Hello注意: 上面是Linux和MAC的例子,在终端里面执行。Windows下则需要替换python3为python,在cmd命令行窗口执行。
一些Python模块也作为脚本使用:python -m module [arg] …。
使用脚本文件时,-i参数可以进入交互模式。
比如有test.py文件如下:
print("Hello")
print("World!")执行:
$ python -i test.py Hello World! >>>参数传递
脚本名和附加参数转换成字符串列表传递给sys模块中的argv变量。导入sys模块访问这个列表。列表的长度至少为1,在无脚本无参数时,sys.argv[0]是空字符串。当脚本名为"-"(即标准输入),sys.argv[0]为"-"。使用-c参数时,sys.argv中[0]设置为'-c'。使用-m参数sys.argv中[0]设置为模块的全名。-c或-m之后的选项留在sys.argv中待命令或模块来处理。
可以用sys.argv来处理参数:
#!/usr/bin/env python3# encoding: utf-8import sysprint "script name is", sys.argv[0]if len(sys.argv) > 1: print "there are", len(sys.argv)-1, "arguments:" for arg in sys.argv[1:]: print argelse: print "there are no arguments!"
$ ./test.py 1 2 3script name is ./test.py there are 3 arguments:123
注意:通常python标准模块argparse处理参数会更合适。
交互模式当tty读取命令时解释器为交互模式。主命令提示符为(>>>),从命令提示符(…)用于续行。
$ python
Python 3.7.0 (default, Jun 28 2018, 13:15:42)
[GCC 7.2.0] :: Anaconda, Inc. on linux
Type "help", "copyright", "credits" or "license" for more information.>>> the_world_is_flat = 1>>> if the_world_is_flat:... print("Be careful not to fall off!")
...
Be careful not to fall off!错误处理当错误发生时,解释器打印错误信息和栈跟踪。在交互模式下,它返回主提示符;在文件输入时,打印栈跟踪器后以非零退出状态退出。有些错误致命的,无条件以非零退出的退出,比如内部不一致和内存耗尽。所有的错误信息都写入标准错误流;正常输出写入标准输出。
输入中断符(通常是Control-C或DEL)可以取消输入,命令执行时输入中断引发一个KeyboardInterrupt异常。
执行python脚本Linux系统中,Python脚本可直接执行,就像shell脚本,在文件首行添加如下:
#! /usr/bin/env python3
并添加可执行权限:
chmod +x myscript.py
Windows系统中Python的安装程序会自动关联.py到python.exe,双击即可运行。.pyw则不会出现windows控制台。
源码编码使用的编码ASCIi(默认)以外的字符Python的源文件,可以在行#!之后定义源文件编码:
# -*- coding: encoding -*-
根据这个声明,源文件中的所有字符将用该编码的编码,并可能在用选定的编码书写Unicode字符串。编码列表可以在Python库参考手册的codecshttps://docs.python.org/3/library/codecs.html#module-codecs部分找到。实例:
一般推荐使用utf-8的格式,在网络上比较通用,可以这样设置:
# coding=utf-8
特殊的中文处理可以使用gbk。通常为了正确显示所有的字符,编辑器必须支持utf-8等格式,并有相应的字体。
交互式启动文件(非常用)交互式使用Python的时候,常常需要在解释器启动时执行一些标准命令。可设置环境变量PYTHONSTARTUP表示启动命令文件,类似Unix shell的.profile文件。
文件只对交互会话有效,当 Python 从脚本中读取命令或以终端/dev/tty做为外部命令源(行为和交互式会话类似)。它与解释器执行的命令在同一命名空间,这样它定义或导入的对象可以在 解释器中使用。也可以在这个文件中改变提示符sys.ps1和sys.ps2。
加载其他文件的方式:
if os.path.isfile('.pythonrc.py'):
execfile('.pythonrc.py')在脚本中使用启动文件如下:
import os
filename = os.environ.get('PYTHONSTARTUP')if filename and os.path.isfile(filename):
execfile(filename)自定义模块(非常用)Python有两个hook: sitecustomize 和 usercustomize。使用它们首先需要知道site-packages目录,方法如下:
>>> import site>>> site.getusersitepackages()'/home/ar/.local/lib/python3.7/site-packages'
现在你可以在site-packages的目录下创建文件usercustomize.py,放入你想添加的任何内容。 该文件会影响 python 的每次调用,除非启动的时候加入-s选项禁止自动导入。
类似的有sitecustomize,但是一般由管理员在全局site-packages创建,在usercustomize之前导入,更多资料参见site模块https://docs.python.org/3/library/site.html#module-site。
开始用turtle绘制长度为10像素的正方形(初级)
image
参考代码:
#!/usr/bin/env python3# -*- coding: utf-8 -*-# Author: xurongzhong#126.com wechat:pythontesting qq:37391319# 技术支持 钉钉群:21745728(可以加钉钉pythontesting邀请加入) # qq群:144081101 591302926 567351477# CreateDate: 2018-6-07# square.py# Draw a squarefrom turtle import * forward(100) left(90) forward(100) left(90) forward(100) left(90) forward(100) left(90) exitonclick()
注意:pycharm之类的IDE虽然功能比较强大,但是很消耗资源,经常有环境配置的问题,建议使用wingide,spyder,vscode等比较轻便的ide或者直接用命令行执行。
| 方法 | 功能 |
|---|---|
| forward(distance) | 向前移动distance |
| backward(distance) or back(distance) | 向后移动distance |
| left(angle) | 左转angle度 |
| right(angle) | 右转angle度 |
| setheading(angle) | 旋转指向,0为向右,旋转方向为逆时针。 |
| exitonclick() | 点击时关闭窗口 |
| pendown() | 移动时绘制 |
| penup() | 移动时不绘制。 |
| circle(radius, extent) | 沿给定半径的圆移动。 可选范围指定弧角。 |
| dot(size) | 在当前位置绘制尺寸为size的点。 |
注意:不要将任何程序文件命名为turtle.py,这样无法导入turtle。
作者:python作业AI毕业设计
链接:https://www.jianshu.com/p/4293aa96fd60



