如何在python解释器中执行.py文件中的代码?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在python解释器中执行.py文件中的代码?相关的知识,希望对你有一定的参考价值。
我在网上学习时看到的方法是
要想运行Python程序,可以在Dos提示符下切换到Python程序文件所在目录,就上例而言,因为我们的示例程序位于C:\python25\test目录下,可以用下列命令:
cd C:\python25\test
然后,在命令提示符下输入python,后跟要执行的程序名即可,如要运行hello.py,可以使用以下命令:
python hello.py
但我在自己机器上建同样的文件,用这个方法行不通,他这个是2.5.1版的python,我的是2.6.2,是不是版本问题?
提问者的问题不是版本的差异:
找到Python的安装路径,并复制;
设置环境变量:计算机--属性--更改设置--高级--环境变量--Path--编辑;
打开cmd,输入:Python py文件全路径即可:
另外,根据经验,可能是你没有把python.exe所在目录添加进系统环境变量Path中 参考技术B 应该是你没有进行好环境配置,
给你个建议 到C:\Documents and Settings\Administrator
下创建 python.bat 编辑
@SET PATH=%
PATH%;c:\python25
@d:
@cd d:\python\
然后在D盘在创建个python 文件夹,把hello.py放进去
运行CMD 然后 python.bat
跳转到d:\python\ 然后就可以直接运行hello.py 不用打python
看看行不行 参考技术C 不是版本的问题 ,有两种可能
1,你的可能前面不用 加 python的
2,你把你的2.6.2卸载调,再装一次本回答被提问者采纳 参考技术D 你所谓的行不通是指什么?运行后无输出?
Python入门
第一句Python代码
编写第一个Python文件hello.py:
print("Hello.Python")
执行hello.py文件:
python3 hello.py
Hello.Python
Python内部执行过程:
解释器
上一步执行hell.py文件时指定了要用python3这个解释器来解释执行。如果想要像执行shell脚本那样执行hello.py文件,那么就需要在hello.py文件开头指定解释器。
#!/usr/bin/python3 print("Hello.Python")
在.py文件开头指定了解释器之后,就直接可以./hello.py来执行python文件,前提是要先给hello.py文件加上可执行权限。
chmod +x hello.py ll hello.py -rwxr-xr-x 1 root root 42 7月 23 18:41 hello.py*
执行hello.py文件:
./hello.py
Hello.Python
内容编码
python解释器在加载 .py 文件中的代码时,会对内容进行编码(Python 2.x默认ascill,Python 3.x默认编码为utf-8)
ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。
显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode
Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,
注:此处说的的是最少2个字节,可能更多
UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...
所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:
#!/usr/bin/python print("你好,世界!")
利用Python2解释器运行该代码:
./helloworld.py File "./helloworld.py", line 3 SyntaxError: Non-ASCII character ‘\\xe4‘ in file ./helloworld.py on line 3, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details
如此可知,Python 2默认不支持中文,所以我们需要在helloworld.py文件中指定编码类型:
#!/usr/bin/python # -*- coding:utf-8 -*- print("你好,世界!")
然后再次利用Python2解释器执行:
./helloworld.py
你好,世界!
Python 3.x 默认编码为utf-8,所以我们不需要在py文件中指定编码类型就可以支持中文:
cat helloworld.py #!/usr/bin/python3 print("你好,世界!")
helloworld.py文件中指定解释器为python3:
./helloworld.py
你好,世界!
注释
当行注视:# 被注释内容
多行注释:""" 被注释内容 """
示例:
cat s1.py #!/usr/bin/python3 # -*- coding:utf-8 -*- #Author:jie.fang #这里是单行注释 if 1 == 1: print("11111") else: print("22222") ‘‘‘ 注释可以方便开发者更好的与同事沟通, 也方便日后自己阅读代码,在执行过程中不会被解释器解释执行 这里是注释 这里是注释 这里也是注释 ‘‘‘
执行s1.py:
./s1.py
11111
执行脚本传入参数
Python有大量的模块,从而使得开发Python程序非常简洁。类库有包括三中:
- Python内部提供的模块
- 业内开源的模块
- 程序员自己开发的模块
Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数:
cat sys.py #!/usr/bin/python3 import sys print(sys.argv)
执行sys.py文件并传入参数:
./sys.py qwe [‘./sys.py‘, ‘qwe‘]
pyc 文件
执行Python代码时,如果导入了其他的 .py 文件,那么,执行过程中会自动生成一个与其同名的 .pyc 文件,该文件就是Python解释器编译之后产生的字节码。
ps:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。
变量
变量申明
cat variable.py #!/usr/bin/python3 name = "jack"
这里申明了一个变量,变量名为"name",变量值为"jack"。
变量的作用跟linux系统中的别名差不多,类似昵称,其代指内存里某个地址中保存的内容。
变量定义的规则
- 变量名只能是 字母、数字或下划线的任意组合
- 变量名的第一个字符不能是数字
- 以下关键字不能声明为变量名
[‘and‘, ‘as‘, ‘assert‘, ‘break‘, ‘class‘, ‘continue‘, ‘def‘, ‘del‘, ‘elif‘, ‘else‘, ‘except‘, ‘exec‘, ‘finally‘, ‘for‘, ‘from‘, ‘global‘, ‘if‘, ‘import‘, ‘in‘, ‘is‘, ‘lambda‘, ‘not‘, ‘or‘, ‘pass‘, ‘print‘, ‘raise‘, ‘return‘, ‘try‘, ‘while‘, ‘with‘, ‘yield‘]
变量的赋值
#!/usr/bin/python3 name1 = "jack" name2 = "lily"
#!/usr/bin/python3 name1 = "jack" name2 = name1
获取用户输入
#!/usr/bin/python3 #将用户输入的内容赋值给变量 name = input("请输入人用户名") #打印输入的内容 print(name)
运行结果:
./getinput.py
请输入人用户名yi
yi
输入密码时,如果想要密码不可见,可以利用getpass 模块中的 getpass方法,即:
#!/usr/bin/python3 import getpass #将用户输入的内容赋值给变量 name = input("请输入人用户名:") passwd = getpass.getpass("请输入密码:") #打印输入的内容 print("用户名:",name,"\\n密码:",passwd)
运行结果:
./getinput.py
请输入人用户名:jie
请输入密码:
用户名: jie
密码: 1234565
流程控制和缩进
示例一:用户登录验证
#!/usr/bin/python3 import getpass #定义好用户名和密码 username = "jie" passwd = "jie123" #提示用户输入用户名和密码 name = input("请输入用户名:") password = getpass.getpass("请输入密码:") #判断用户名和密码是否正确 if name == username and password == passwd: print("欢迎您,%s"%name) else: print("用户名或密码错误!")
运行结果:
./login.py
请输入用户名:jie
请输入密码:
欢迎您,jie
示例二:在示例一的基础上加上次数限制演示错误超过三次:
#!/usr/bin/python3 import getpass count = 1 #定义好用户名和密码 username = "jie" passwd = "jie123" while count < 4: #提示用户输入用户名和密码 name = input("请输入用户名:") password = getpass.getpass("请输入密码:") #判断用户名和密码是否正确 if name == username and password == passwd: print("欢迎您,%s"%name) break else: print("用户名或密码错误!") count += 1 if count == 4: print("错误次数达到(3次)上限,退出...")
演示错误输入超过3次:
./login.py
请输入用户名:jie
请输入密码:
用户名或密码错误!
请输入用户名:jie
请输入密码:
用户名或密码错误!
请输入用户名:jie
请输入密码:
用户名或密码错误!
错误次数达到(3次)上限,退出...
演示成功登陆:
./login.py
请输入用户名:jie
请输入密码:
用户名或密码错误!
请输入用户名:jie
请输入密码:
用户名或密码错误!
请输入用户名:jie
请输入密码:
欢迎您,jie
while循环
基本循环:如果条件为真,那么执行while循环,否则,跳出循环继续执行循环下面的语句
#!/usr/bin/python3 i = 1 while i <= 10: print(i) i += 1 print("当i=11的时候会跳出循环")
执行结果:
./while.py 1 2 3 4 5 6 7 8 9 10 当i=11的时候会跳出循环
break:while循环执行,遇到break则跳出所有循环,执行循环外的其他语句
#!/usr/bin/python3 i = 1 while i <= 10: if i == 7: break print(i) i += 1 print("当i=7的时候,遇到break,退出循环,执行这条语句")
执行结果:
./while.py 1 2 3 4 5 6 当i=7的时候,遇到break,退出循环,执行这条语句
continue:while循环遇到continue的时候,跳过档次循环,进入下一个循环
#!/usr/bin/python3 i = 1 while i <= 10: if i == 7: i += 1 print("跳过这次循环,继续下一次循环") continue print(i) i += 1 print("当i=7的时候,遇到continue,退出i=7的循环,知道循环结束,执行这条语句")
执行结果:
./while.py 1 2 3 4 5 6 跳过这次循环,继续下一次循环 8 9 10 当i=7的时候,遇到continue,退出i=7的循环,知道循环结束,执行这条语句
以上是关于如何在python解释器中执行.py文件中的代码?的主要内容,如果未能解决你的问题,请参考以下文章