python详细介绍
1、python的前世今生
python是由吉多,范罗苏姆在1989年圣诞节完成的,当时主要是为了替代ABC语言。
C是执行之前是通过C语言的虚拟机编译为机器码之后执行的,而python是编译为字节码执行的,cpython是由C语言写成的,所以,执行速率较C语言慢很多。
到目前(2015-12-02)为止,python位于编程语言排行榜第5位,首次超过php,未来预计其市场份额还会增加。
python也称为胶水语言,是因为python可以嵌入其他如java、C++等语言中使用。
2、python的应用
数据分析:一般是针对TB以上的数据文件做分析
系统编程:做系统接口
组件集成:做系统组件
网络服务:目前python使用较多的领域,如爬虫、CGI、WSI等
图像处理:可以替代matlab 90%以上的功能
数值计算和科学计算
目前youTube、Dropbox、BT、QUora(中国知乎)、Google、Yahoo!、Facebook、NASA等大量使用python。
3、为什么使用python
C语言使用的时候内存的管理和申请和释放,需要程序员自己写,而python类似于大多数的面向对象的编程语言,内存是由内置的虚拟机分配的;
a、python相较与C语言运行速度很慢,但是程序运行的快慢多数情况下是由程序员的水平决定的,并且大多数情况下,程序由于语言本身的快慢造成的响应时间人是很难察觉到的,类似于0.0001s和0.01s,我们感觉差别不大。
b、由摩尔定律可以知道,现在硬件的处理速度非常快了,程序的运行速率也较快。
c、python提供了非常强大的类库。
4、python的种类
Cpython
Jpython
Tronpython
pypy
Rubypython
python文件 python核心(解释器) 运行环境
内置模块 词法分析 对象和类型
类库 语法分析 内存和管理
自定义模块 编译
执行 状态
5、字符编码
ASCII:2的8次方=256个字符
unicode(万国码):最少2的16次方个字符,可以表示中文,但是unicode编码不能写入硬盘。
utf-8:对unicode进行加工,对通过8位可以表示的,用8位表示,可以用16位表示的,用16位表示,对可以用32位表示的用32位表示,这样的话节省内存空间,也可以写入硬盘。
二、初始python
1、第一句python代码
>>> print 'hello world!!!'
hello world!!!
2、python解释器声明
#!/usr/bin/env python
3、编码以及编码声明
# _*_ coding:utf-8 _*_
4、注释
单行注释#
''' '''多行注释
5、脚本参数
import
sys.argv #将输入的参数$0,$1...放到一个列表当中,类似于shell的$*
6、字节码
如果在一个文件中导入文件m.py文件,那么产生m.pyc文件,如果m.py文件和m.pyc文件的功能相同,那么优先导入m.pyc文件
7、变量
代指内存里某个地址中保存的内容
name1="changqiangqiang"
name2=name1
如果此时name1改变,但是name2不变
但是如果name1不是字符串而是集合,那么name2也会改变;
在C语言中,没有字符串,但是有字符,比如hello由5个字符组成,由于python是由c实现的,所以python的字符串由C的字符数组['h','e'...'o']组成。
字符串特性:一旦修改,就需要重新创建,(中心开辟空间)。
万恶的"+"号:如果字符串使用“+”号叠加,每一个"+"号,都需要重新到内存中开辟一块空间,导致性能下降.
数据结构有两种类型:
第一种是直立型:只要值改变,就需要重新开辟空间;
第二种是引用类型:值改变,不需要重新开辟空间;
python缓冲池的概念
在一定的数值范围内,即咋缓冲池内的字符串,相同变量指向相同的字符串,id值相同。
python解释器执行的过程:加载内存-->词法分析-->语法分析-->编译-->字节码(c语言为机器码)-->执行
8、python的输入输出
name=raw_input(">>>")
import getpass
pwd=getpass.getpass(">>>")
9、流程控制
"=="只表示值相同,"is"标志内存地址相同
if...
elif ...
else...
10、初始基本数据类型
范围两类:
第一类是单值:数字、字符串、布尔值
第二类是集合:列表、元组、字典、哈希表(set)
字符串:万恶的字符串拼接(+),不要用,使用字符串格式化替代
两种字符串格式化:
第一种:name="i am %s" %('QQ')
第二种:name="i am {0} age{1}"
print name.format('alex',18)
字符串的切片:name='hello' name[0]='a' name[0:2]='he'
len(name)-->多少个字符 name[-1]==name[len(name)-1]
字符串的分割:names="QQ,hello" name.split(",")=["QQ","hello"]-->字符分割的结果为列表
创建的列表本质上讲都是对象,字符串和列表都支持索引
总结:
字符串的常用功能:
移除空白
分割
长度
索引
切片
列表的常用操作:列表内容修改,内存地址不发生改变(id值相同),不会创建新的内存空间
索引
切片
追加
删除
长度
循环
包含
转换为字符串(与分割相反)
str、list和tuple的相同点和不同点:
相同点:切片、索引、len()、包含、循环;
不同点:str修改后重新开辟空间,list修改后内存地址不变,tuple不允许修改;
字典:键值对,字典是无序的
字典的循环: for k,v in name.items():
print k,v
12、初识文本操作
找到文件
打开文件:file_obj=file(文件路径,模式)
文件操作,读写:file_obj.read() #将文本内容全部写入内存,写入的数据格式为字符串
file_obj.readline() #一次读取一行数据,为字符串格式;
file_obj.readlines() #将文本内容全部读入内存,并按行存入列表当中,列表的每一个元素为一行数据
模式: r-->读 w-->如果文件存在,则将其重写 a-->追加 w+(读写)
循环:
for line in file_obj.readlines: #每次循环,只读一行,避免全部读入内存
for line in file_obj.xreadlines(): #xreadlines表示迭代器,直接打印会显示文件句柄的内存地址,默认不会打印出来,只有在循环迭代器的时候才会将每一个元素一一显示;
file_obj.write() #是将字符串作为参数传入,将字符串的内容写入文件中
file_obj.writelines() #传入的参数除了字符串,还可以是字符串序列,比如列表,或者字典等等,也就是说writelines比write更强大;
file_obj.close() #关闭文件
练习:
要求:编写登陆接口,输入用户名和密码,认证成功后显示欢迎信息,输错三次后锁定。
#!/usr/bin/env python # _*_ coding:utf-8 _*_ import getpass import sys chiper_file='account.txt' limit_times=0 lock_file='lock_file.txt' chiper_dict={} lock_file_list = [] while limit_times < 3: username=raw_input('请输入用户名:').strip() f = file(lock_file,'r') for line in f.readlines(): line = line.strip() lock_file_list.append(line) f.close() if username in lock_file_list: print "