Python学习【02】Python基础

2022-12-30,,

一、Python内部执行过程

1、Python的后缀名可以是任意?

print("hello,world")  保存成  .py / .txt / .sb / .aaa 都可以用在cmd用Python执行

2、导入模块时,如果不是.py文件,就会报错

3、以后文件后缀名都要是 .py

二、解释器

指定由Python解释器执行Python脚本

如果想类似执行shell脚本一样执行hello.py脚本,例如: ./hello.py ,那么需要在hello.py文件的头部指定解释器,如下:

#!/usr/bin/env python

print("hello,world")

如此一来,执行: ./hello.py   即可。

注意:执行前需要给予 hello.py 执行权限,chmod 755 hello.py

Python交互式环境的提示符: >>>

Windows命令行模式的提示符: C:>

在Python交互式环境下直接输入代码,按回车,就可以立刻得到代码执行结果,但是在命令行模式下,执行 Python ##.py文件时,并不会。

在命令行模式下,可以执行python进入Python交互式环境,也可以执行python hello.py运行一个.py文件

两种文本编辑器:Sublime Text 、 Notepad++

执行python文件,在命令行中,切换到该Python文件所在的目录下,然后输入 Python ###.py命令就可以了。

CPython用>>>作为提示符,而IPython用In [序号]:作为提示符。

Python交互模式主要是为了调试Python代码用的,也便于初学者学习,它不是正式运行Python代码的环境!

Python的交互模式直接运行.py文件有什么区别呢?

直接输入python进入交互模式,相当于启动了Python解释器,但是等待你一行一行地输入源代码,每输入一行就执行一行。

直接运行.py文件相当于启动了Python解释器,然后一次性把.py文件的源代码给执行了,你是没有机会以交互的方式输入源代码的。

三、内容编码

python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)

ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。

Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,
注:此处说的的是最少2个字节,可能更多

UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...

报错:ascii码无法表示中文

 #!/usr/bin/env python

 print "你好,世界"

改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:

 #!/usr/bin/env python
# -*- coding: utf-8 -*- print "你好,世界"

注意:

1、/usr/bin/env 在Windows下其实并不需要

2、/usr/bin/env 是Python在Linux下的路径,当在Linux系统通过命令: ./name.py 执行Python文件时,告诉Linux使用Python解释器。

3、# -*- coding:utf8 -*-,在Python2中要加上才能显示中文,否则报错;在Python3中可以不加。

4、utf8:中文用3字节;   gbk:中文用2字节

四、注释

  单行注视:# 被注释内容

  多行注释:""" 被注释内容 """

五、执行脚本传入参数

Python有大量的模块,类库有三种:

Python内部提供的模块
业内开源的模块
程序员自己开发的模块

例如:

Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数

 #!/usr/bin/env python
# -*- coding: utf-8 -*- import sys print sys.argv

六、pyc文件

执行Python代码时,如果导入了其他的 .py 文件,那么,执行过程中会自动生成一个与其同名的 .pyc 文件,该文件就是Python解释器编译之后产生的字节码。

注意:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。

七、变量

1、声明变量

name = "tom"

# name:变量名, tom:变量的内容, =:赋值号

变量的作用:通过符号指代内存中的某个内容

变量定义的规则:

变量名只能是 字母、数字或下划线的任意组合
变量名的第一个字符不能是数字
以下关键字不能声明为变量名
['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']

2、变量的赋值

name1 = "wupeiqi"
name2 = "alex"

name1 = "wupeiqi"
name2 = name1

八、输入

获得用户输入:input函数

例如:

>>> name = input("请输入用户名:")
请输入用户名:tom
>>> name
'tom'

输入密码时,如果想要不可见,需要利用getpass 模块中的 getpass方法,即:

>>> import getpass
>>> pwd = getpass.getpass()
Passwd:
>>> pwd
123456

注意:Python自带的ide不支持隐藏回显,用Windows的cmd就可以

九、流程控制和缩进

示例一:用户登录验证

#!/usr/bin/env python
# -*- coding: utf-8 -*- # 加载getpass库
import getpass name = input('请输入用户名:')
pwd = getpass.getpass('请输入密码:') if name == "tom" and pwd == "":
print "欢迎,tom!"
else:
print "用户名和密码错误"

示例二:根据用户输入内容输出其权限

# 根据用户输入内容打印其权限

# alex --> 超级管理员
# eric --> 普通管理员
# tony,rain --> 业务主管
# 其他 --> 普通用户 name = raw_input('请输入用户名:') if name == "alex":
print "超级管理员"
elif name == "eric":
print "普通管理员"
elif name == "tony" or name == "rain":
print "业务主管"
else:
print "普通用户"

十、while循环

1、基本循环

while <条件>:
<循环体> # 如果条件为真,执行循环体
# 如果条件为假,不执行循环体

2、

break:结束循环

continue:跳过当前循环,直接开始下一次循环

要特别注意,不要滥用break和continue语句。break和continue会造成代码执行逻辑分叉过多,容易出错。大多数循环并不需要用到break和continue语句,上面的两个例子,都可以通过改写循环条件或者修改循环逻辑,去掉break和continue语句。

有些时候,如果代码写得有问题,会让程序陷入“死循环”,也就是永远循环下去。这时可以用Ctrl+C退出程序,或者强制结束Python进程。

Python学习【02】Python基础的相关教程结束。

《Python学习【02】Python基础.doc》

下载本文的Word格式文档,以方便收藏与打印。