内容
- Python介绍
- 安装
- Hello World程序
- 变量
- 用户输入
- if..else流程判断
- while循环
- for循环
- 作业需求
3 、 Python入门
在后面的操作中,主要以python 3.4 版本为主:
Python脚本执行
1 | 在linux 下创建一个文件叫hello.py,并输入: |
2 | print("hello world ") |
3 | 然后执行命令:python hello.py ,输出: |
4 | $ python hello.py |
5 | Hello World! |
指定解释器
上一步中执行 python hello.py 时,明确的指出 hello.py 脚本由 python 解释器来执行。
如果想要类似于执行shell脚本一样执行python脚本,例: ./hello.py
,那么就需要在 hello.py 文件的头部指定解释器
1 | #!/usr/bin/python env |
2 | print ("hello world") |
执行前:chmod +x hello.py
就可以如下执行:./hello.py 即可。
在交互器中执行
可以直接调用python自带的交互器运行代码 :
4、变量\字符编码
1、声明变量:
#_*_coding:utf-8_*_ |
name = 'Chen" |
print name |
解析:#_*_coding:utf-8_*_ 指定字符编码 ,name 为变量名, 变量名的值为:“Chen” ;print 打印
2、变量的赋值:
1 | name = "chen" |
2 | name2 = name |
3 | |
4 | print ("1、" ,name,name2) |
5 | |
6 | name = "ChcnChangQing" |
7 | print ( "2、",name,name2) |
结果打印:
解析:给name 赋一个值常量固定值,name2等于name 的值,同时python内存池也给name 分配了一个模块值, name、name2的指针指向同一个值。 所以第一次打印,name、name2的值是一样的;第二次重新指定name的值是,python会划分一个地址池,name的指针发生改变指向新的地址池,这个时候name2并不会随着name的改变而改变,还是指向原理的地址池。所以第二次打印出来的结果值,name与name2不一样。
3、变量定义规则:
- 变量名只能是字母、数字或下划线的任意组合,注意变量名称数字不能放在前面 。如:2ff = "chen" 格式错误;_2ff = "chen" ; ff2 = "chen" 这种类格式是可以正常识别的
- 变量名的第一个字符不能是数字
- 以下关键字不能做为变量名(python规定):
['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']
4、字符编码与二进制:
A、数字与二进制的换算:
描述:定位数字的值,往前去累加。当当前数值大于排列数字就在下方标1 如:165 小于256 大于128,所以在128下标1,再往前推算,排列的数据小于剩下的数值 (165-128),下方标零,截止排列数据的和等于165=128+32+4+1,从中推算出二进制为:10100101
B、字符编码
python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认Ascill)
ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256-1,所以,ASCII码最多只能表示 255 个符号。
关于中文的发展(摘录):
为了处理汉字,程序员设计了用于简体中文的GB2312和用于繁体中文的big5。
GB2312(1980年)一共收录了7445个字符,包括6763个汉字和682个其它符号。汉字区的内码范围高字节从B0-F7,低字节从A1-FE,占用的码位是72*94=6768。其中有5个空位是D7FA-D7FE。
GB2312 支持的汉字太少。1995年的汉字扩展规范GBK1.0收录了21886个符号,它分为汉字区和图形符号区。汉字区包括21003个字符。2000年的 GB18030是取代GBK1.0的正式国家标准。该标准收录了27484个汉字,同时还收录了藏文、蒙文、维吾尔文等主要的少数民族文字。现在的PC平台必须支持GB18030,对嵌入式产品暂不作要求。所以手机、MP3一般只支持GB2312。
从ASCII、GB2312、GBK 到GB18030,这些编码方法是向下兼容的,即同一个字符在这些方案中总是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文可以统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB2312、GBK到GB18030都属于双字节字符集 (DBCS)。
有的中文Windows的缺省内码还是GBK,可以通过GB18030升级包升级到GB18030。不过GB18030相对GBK增加的字符,普通人是很难用到的,通常我们还是用GBK指代中文Windows内码
ASCII码无法将世界上的各种文字和符号全部表示,所以新出一种可以代表所有字符和符号的编码,即:Unicode
Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,
所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如下代码:
报错:Ascii码无法表示中文
1
2
3
|
#!/usr/bin/env python
print
"你好,世界"
|
改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:
1
2
3
4
|
#!/usr/bin/env python
# -*- coding: utf-8 -*-
print
"你好,世界"
|
5、用户输入
1、注释分两种:
- 注释当行: # 被注释内容
- 注释多行:"""被注释的内容"""
举例:可以利用多行注释,进行多行打印 :(博客园添加不了表格。。。。)
example = """
执行效果:
2、 用户输入:Iput使用
A、 格式化输出的几种形式
备注:+ 号拼接;%s/%d/%f 赋值 ; format 赋值; 使用{} 按照数字值拼接。举例如下:
a、+号的拼接:
举例:
结果:
解析:一个个字段的相加打印
b、% 赋值(%就相当于shell中的$)
举例:
结果:
解析:%s 针对于字符串,如果是是int 类型对应的是 %d,浮点数为 %f。注意数据类型的转换。
判断一个值的类型 type('值') ,会得出这个值的类型
举例:
print type(name)
返回结果
c、 format 赋值
举例:
结果:
解析:使用format赋值,不用考虑数据类型
d、 使用{} 按照数字顺序拼接
举例:
结果:
B、使用getpass模块隐藏密码输入
举例:密码可见
结果:
举例:密码不可见 (使用getpass)
1
|
#/usr/bin/env python
|
2 |
#--*-- code:utf-8 --*--
|
3
|
|
4 | import getpass |
5 | username = input("name:") |
6 | |
7 | password = getpass.getpass("请输入密码:") |
8 | |
9 | print (username,password) |
结果:
1 | 找到执行所在的目录 |
2 | C:\Users\chen>cd /d D:\python\51CTO\day1 |
3 | 执行文件、输入用户名、输入密码、并打印 |
4 | D:\python\51CTO\day1>python hello.py |
5 | name:chen |
6 | passwd: |
7 | ('chen', 'chen') |
getpass 有待验证,在PyCharm中测试不成功。需要在liunx 系统中、window系统的cmd中验证。
C、Input 在 python2与python3 中的区别:
python2 有input\raw_input;pyhton3 只有Input。py2 中的raw_input功能等同于py3中的input。要避免在PYthon2 中使用Input ,raw_input与及python3中input 输入的永远是字符串。
Pyhton2 的Input输入的是什么格式,就是什么格式。在PY2中的测试:
举例:错误
print name
返回结果:
执行结果:Abc 没有被定义
举例:改正 (把Abc给定义一个数值)
返回结果:
name:Abc
123456
输入Abc 把 Abc 的值给打印出来。结论:Python2 中要使用Input 要先把输入值给定义好。
六、if..else语句 流程判断
1、判断用户登录验证
举例 if..else 结构:
结果:
错误打印
正确打印
2、猜数字:
举例 if..elif..else 结构:
#定义固定数字
结果:
The number is bigger!
七、while 循环
1、死循环模式
举例:
1 | #定义计数器 |
2 | count = 0 |
3 | while True: |
4 | print("count:",count) |
5 | #count += 1 等同于count = count + 1,计算步长 |
6 | count +=1 |
结果无限打印,环境中杜绝死循环。
2、简单的从0打印到5:
举例:
1 | #定义计数器 |
2 | count = 0 |
3 | while count < 6: |
4 | print("count",count) |
5 | count +=1 |
结果:
1 | count: 0 |
.. | .. |
3、接着猜数字:要求只允许用户猜三次,要求猜对直接退出。三次都都猜不对,打印文字告知用户错误。
举例:
结果:
4、接着上面的列子,猜数字。猜够三次还想继续玩:
举例:
结果:
八、for循环
rang(10) #表示从零开始计算打印10个数:0-9
rang(1,10) # 表示从1开始打印,打印:1-9
rang(1,10,3) #表示从1开始打印,相隔3个数字打印一次,数字小于10
举例:
输出:
循环中break and continue 的用法
备注:break结束本次循环、continue跳出本次循环进入下次循环。
1、遇到小于6的循环次数就不走了,直接跳入下一次循环
输出:
number1 7
2、遇到大于4 的循环次数就不走了,直接退出
输出:
九、作业需求
作业一:编写登陆接口
- 输入用户名密码
- 认证成功后显示欢迎信息
- 输错三次后锁定
通过其他的方方式编写