Python入门介绍
Python入门介绍(人生苦短,我用 Python)
Python简介
python的创始人为吉多·范罗苏姆(Guido van Rossum)。1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承。
Python的种类
- Cpython
Python的官方版本,使用C语言实现,使用最为广泛,CPython实现会将源文件(py文件)转换成字节码文件(pyc文件),然后运行在Python虚拟机上。 - Jyhton
Python的Java实现,Jython会将Python代码动态编译成Java字节码,然后在JVM上运行。 - IronPython
Python的C#实现,IronPython将Python代码编译成C#字节码,然后在CLR上运行。(与Jython类似) - PyPy(特殊)
Python实现的Python,将Python的字节码字节码再编译成机器码。 - RubyPython、Brython ...
以上除PyPy之外,其他的Python的对应关系和执行流程如下:
PyPy,在Python的基础上对Python的字节码进一步处理,从而提升执行速度!
Python环境
-
windows7安装(python2)
1、官网下载地址:https://www.python.org/downloads/
下载后软件名示例:python-2.7.10.amd64.msi
2、安装,选择安装路径D:\Python27
3、环境变量配置
我的电脑属性 –> 高级系统设置 –> 高级 –> 环境变量 –> 系统变量中选择Path,加入;D:\Python27
如:原来的值;C:\python27,切记前面有分号
4、开始 –> cmd 进入命令提示符 –> 输入python如下图提示表示安装成功,版本为2.7.10
- windows7安装(python3)
下载64位程序包python-3.5.2-amd64.exe
选择
下一步
windows python3.5和2.7 共存
D:\Program Files\Python35目录下python.exe重命名为python3.exe
关于pip的使用
若需要安装Python2的库,执行python -m pip install xxxx即可,xxxx是库的名字。
若需要安装Python3的库,执行python3 -m pip install xxxx即可。
-
Linux安装(python2)
yum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python,查看默认Python版本 python -V
1、安装gcc,用于编译Python源码
yum install -y make zlib zlib-devel gcc-c++ libtool openssl openssl-devel gcc ncurses-devel libpcap-devel wget bzip2-devel
2、下载源码包
https://www.python.org/ftp/python/
3、解压并进入源码文件
4、编译安装
mkdir -p /usr/local/python/2.7.10/lib
./configure --enable-shared --prefix=/usr/local/python/2.7.10 LDFLAGS="-Wl,-rpath /usr/local/python/2.7.10/lib"
make
make install
5、查看版本
/usr/local/python/2.7.10/bin -V
6、修改默认Python版本
mv /usr/bin/python /usr/bin/python2.6
ln -fs /usr/local/python/2.7.10/bin/python2.7 /usr/bin/python
7、防止yum执行异常,修改yum使用的Python版本
vi /usr/bin/yum
将头部 #!/usr/bin/python 修改为 #!/usr/bin/python2.6
-
Linux安装(python3)
yum install -y make zlib zlib-devel gcc-c++ libtool openssl openssl-devel gcc ncurses-devel libpcap-devel wget bzip2-devel
tar zxvf Python-3.5.2.tgz
cd Python-3.5.2
mkdir -p /usr/local/python/3.5.2/lib
./configure --enable-shared --prefix=/usr/local/python/3.5.2 LDFLAGS="-Wl,-rpath /usr/local/python/3.5.2/lib"
make
make install
ln -fs /usr/local/python/3.5.2/bin/python3.5 /usr/bin/python3
二、Python初学
1、第一句python代码
print “Hello World!”
2、解释器声明
了解python代码内部执行
小结:
Python经过解释器分析哪几个阶段:
加载内存–> 词法分析–> 语法分析–> 编译字节码–> 执行字节码–> 机器码
3、编码以及编码声明
① ASCII
(American Standard Code for Information Interchange,美国标准信息交换代
码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。
② Unicode
Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。
Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536
③ UTF-8
utF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存..
小结:
编码3种:ascii(256个,二进制8位长度表示)、unicode(至少二进制16位长度表示)、utf-8(同时可满足ascii和unicode两种表示,减少内存占用)
Python2.7版本默认是ascii码,只持256个,如果需要支持中文等字符,需使用utf-8编码模式,建议在代码的开头加入如下内容。声明编码
# -*- coding:utf-8 -*-
4、注释
- 单行注释用
- #多行注释用3个单引号或3个双引号表示
5、脚本参数
# -*- coding: utf-8 -*- import sys print sys.argv #捕获参数
Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数
6、字节码
Python中文件后缀为pyc的是字节码文件,它是经过python编译后生成的。
如果py和pyc内容相同,优先执行pyc文件;如果py和pyc不同,优先执行py文件。
备注:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。
7、变量
1)系统关键字不要使用作为变量名
2)修改字符串,重新开辟空间,字符数组表示字符是连续的
3)==是值跟值对比,不是内存地址对比
4)is表示两个内存地址相同
# -*- coding: utf-8 -*- name = "wj_test"
上述代码声明了一个变量,变量名为: name,变量name的值为:"wj_test"
变量的作用:昵称,其代指内存里某个地址中保存的内容
变量定义的规则:
- 变量名只能是 字母、数字或下划线的任意组合
- 变量名的第一个字符不能是数字
- 以下关键字不能声明为变量名
['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']
变量的赋值
# -*- coding: utf-8 -*- name1 = "wang1" name2 = "wang2"
# -*- coding: utf-8 -*- name1 = "wang" name2 = name1
8、输入输出
输入raw_input和getpass,需要导入getpass模块,隐藏输入的密码
输出print,例:
# -*- coding:utf-8 -*- import getpass name = raw_input("请输入你的名字:") pwd = getpass.getpass("你的密码:") print pwd
9、流程控制
1)If … else…
1 name = raw_input("请输入你的名字:") 2 if name == "wangjian": 3 print "登录成功" 4 else: 5 print "登录失败"
2)If … elif … else …
1 import getpass 2 name = raw_input("请输入你的名字:") 3 pwd = getpass.getpass("你的密码:") 4 if name == "wangjian" and pwd == "123": 5 print "登录成功,普通用户" 6 elif name == "wangjian10" and pwd == "123": 7 print "登录成功,超级用户" 8 elif name == "wangjian100" and pwd == "123": 9 print "登录成功,超神用户" 10 else: 11 print "登录失败"
10、数据类型
单值
- 数字
int(整型)
在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
long(长整型)
跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。
注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。
float(浮点型)
浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。
complex(复数)
复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
注:Python中存在小数字池:-5 ~ 25
- 布尔值
True或False
1 或 0
- 字符串
"hello world"
万恶的字符串拼接:
python中的字符串在C语言中体现为是一个字符数组,每次创建字符串时候需要在内存中开辟一块连续的空,并且一旦需要修改字符串的话,就需要再次开辟空间,万恶的+号每出现一次就会在内从中重新开辟一块空间。
字符串里可以出现占位符(%s、%d)
字符串的格式化
name = "I am %s ,age %d" %('wangjian',30)
等同于下面
name = "I am %s ,age %d"
name %('wangjian',30)
等同于
name = "I am {0},age {1}"
name.format('wangjian',30)
字符串常用功能:移除空白、分割、长度、索引、切片
集合
- 列表
name_list = ['wang1', 'wang2', 'wang3'] 或 name_list = list(['wang1', 'wang2', 'wang3'])
基本操作:索引、切片、追加、删除、长度、循环、包含
- 元祖
ages = (11, 22, 33, 44, 55) 或 ages = tuple((11, 22, 33, 44, 55))
基本操作:索引、切片、长度、循环、包含
- 字典(无序)
person = {"name": "wang", 'age': 18} 或 person = dict({"name": "wang", 'age': 18})
基本操作:索引,切片,长度,循环,删除,键、值、键值对
- 哈希表
字符串(str)、列表(list)、元祖(tuple)区别:
type()查看变量属于哪个
相同点:切片、索引(-1),长度,包含,循环
不同点:
str 字符串修改重新开辟内存空间
list 修改后,内存空间不变
tuple 不允许修改
dict 键值对,字典无序,特殊的for循环
keys() --> 列表
values() --> 列表
itmes() --> 列表 ,仅for循环使用,将元素复制给key和value
11、循环控制
while 后面条件为真,永远执行,如果后面条件为假,不在执行
for循环
break退出循环,continue退出本次循环,不执行后续的步骤
1 for ele in name_list: 2 print ele 3 if ele == 'wangjian': 4 print "继续下一次" 5 continue #本次循环结束,不再继续执行后面内容 6 if ele == 'wangjian': 7 print "终于等到你" 8 break #退出
12、运算
比较运算:
赋值运算:
逻辑运算:
成员运算:
身份运算:
位运算:
运算符优先级:
http://www.runoob.com/python/python-operators.html
13、文件操作
file_obj = file("文件路径","模式")
# 一次性加载所有内容到内存 obj.read() # 一次性加载所有内容到内存,并根据行分割成字符串 obj.readlines() # 每次仅读取一行数据 for line in obj: print line
文件里读、写 示例,步骤:
1、找到文件
文件路径F:\python_wj\day1
2、打开文件
file_obj = file(文件路径,操作模式)
3、文件操作,读写
file_obj.read() #将所有内容读入内存当中
file_obj.readlins() #将所有内容读入内存当中,根据换行符做成列表,[行,]
for line in file_obj.xreadlins():
print line
等同于
for line in file_obj: #每次循环只读一行,避免全部读入内存
print line
file_obj.write() # 写
file_obj.writeline() #一行一行写
4、文件关闭
file_obj.close()
1 file_obj = file('F:\python_wj\day1\log.txt'.decode('utf-8'), 'r+') 2 line_list = file_obj.readlines() 3 my_list = [] 4 for ele in line_list: 5 #读出第一行 6 line = ele.strip() #去掉换行符\n 7 value_list = line.split(';') #换成列表 8 last_value = int(value_list[-1]) #最后一个数装换成整型 9 last_value += 1 #最后一个数加1 10 value_list[-1] = str(last_value) #加1的数赋值回原来的值 11 #更新后的列表 12 value_str = ';'.join(value_list) 13 my_list.append(value_str) 14 my_str = '\n'.join(my_list) 15 file_obj.write(my_str) 16 file_obj.flush() 17 file_obj.close()