在后面的操做中,主要以python 3.4 版本为主:python
Python脚本执行linux
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 解释器来执行。sql
若是想要相似于执行shell脚本同样执行python脚本,例: ./hello.py
,那么就须要在 hello.py 文件的头部指定解释器shell
1 | #!/usr/bin/python env |
2 | print ("hello world") |
执行前:chmod +x hello.pywindows
就能够以下执行:./hello.py 便可。测试
在交互器中执行编码
能够直接调用python自带的交互器运行代码 :spa
一、声明变量:设计
#_*_coding:utf-8_*_ |
name = 'Chen" |
print name |
解析:#_*_coding:utf-8_*_ 指定字符编码 ,name 为变量名, 变量名的值为:“Chen” ;print 打印
二、变量的赋值:
1 | name = "chen" |
2 | name2 = name |
3 | |
4 | print ("一、" ,name,name2) |
5 | |
6 | name = "ChcnChangQing" |
7 | print ( "二、",name,name2) |
结果打印:
解析:给name 赋一个值常量固定值,name2等于name 的值,同时python内存池也给name 分配了一个模块值, name、name2的指针指向同一个值。 因此第一次打印,name、name2的值是同样的;第二次从新指定name的值是,python会划分一个地址池,name的指针发生改变指向新的地址池,这个时候name2并不会随着name的改变而改变,仍是指向原理的地址池。因此第二次打印出来的结果值,name与name2不同。
三、变量定义规则:
['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']
四、字符编码与二进制:
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、GB23十二、GBK 到GB18030,这些编码方法是向下兼容的,即同一个字符在这些方案中老是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文能够统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB23十二、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
"你好,世界"
|
一、注释分两种:
举例:能够利用多行注释,进行多行打印 :(博客园添加不了表格。。。。)
example = """
执行效果:
二、 用户输入:Iput使用
A、 格式化输出的几种形式
备注:+ 号拼接;%s/%d/%f 赋值 ; format 赋值; 使用{} 按照数字值拼接。举例以下:
a、+号的拼接:
举例:
结果:
解析:一个个字段的相加打印
b、% 赋值(%就至关于shell中的$)
举例:
结果:
解析:%s 针对于字符串,若是是是int 类型对应的是 %d,浮点数为 %f。注意数据类型的转换。
判断一个值的类型 type('值') ,会得出这个值的类型 <type 'str'> 。str 字符串、int 数字、dict 字典、 list 列表
举例:
print type(name)
返回结果
<type 'str'> 得出参数值的类型为字符串
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 结构:
结果:
错误打印
正确打印
二、猜数字:
举例 if..elif..else 结构:
#定义固定数字
结果:
The number is bigger!
一、死循环模式
举例:
1 | #定义计数器 |
2 | count = 0 |
3 | while True: |
4 | print("count:",count) |
5 | #count += 1 等同于count = count + 1,计算步长 |
6 | count +=1 |
结果无限打印,环境中杜绝死循环。
二、简单的从0打印到5:
举例:
1 | #定义计数器 |
2 | count = 0 |
3 | while count < 6: |
4 | print("count",count) |
5 | count +=1 |
结果:
1 | count: 0 |
.. | .. |
三、接着猜数字:要求只容许用户猜三次,要求猜对直接退出。三次都都猜不对,打印文字告知用户错误。
举例:
结果:
四、接着上面的列子,猜数字。猜够三次还想继续玩:
举例:
结果:
rang(10) #表示从零开始计算打印10个数:0-9
rang(1,10) # 表示从1开始打印,打印:1-9
rang(1,10,3) #表示从1开始打印,相隔3个数字打印一次,数字小于10
举例:
输出:
循环中break and continue 的用法
备注:break结束本次循环、continue跳出本次循环进入下次循环。
一、遇到小于6的循环次数就不走了,直接跳入下一次循环
输出:
number1 7
二、遇到大于4 的循环次数就不走了,直接退出
输出:
做业一:编写登录接口
经过其余的方方式编写