1.Python前世今生
1.1.Python历史
Python的创始人: Guido van Rossum;之所以选中Python(大蟒蛇的意思)作为该编程语言的名字,是因为他是一个叫Monty Python的喜剧团体的爱好者。
诞生于1989年。作者前身也是C++程序员,之前也参加设计了一种叫ABC的教学语言,就Guido本人看来,ABC 这种语言非常优美和强大,是专门为非专业程序员设计的。但是ABC语言并没有成功,究其原因,Guido 认为是其非开放造成的(相对封闭的开发语言、扩展性、推广性相对不太成功。)。Guido 决心在Python 中避免这一错误。同时,他还想实现在ABC 中闪现过但未曾实现的东西。
图片来自网络
1.2.热门排行
最新的TIOBE排行榜,Python赶超PHP占据第四。
图片来自网络
由上图可见,Python整体呈上升趋势,反映出Python应用越来越广泛并且也逐渐得到业内的认可!
图片来自网络
IEEE Spectrum (电气和电子工程师协会) 2017 编程语言 Top 10
http://spectrum.ieee.org/static/interactive-the-top-programming-languages-2017
图片来自网络
图片来自网络
1.3.Python应用领域
云计算最火的语言, 典型应用OpenStack
python相比php\ruby的模块化设计,非常便于功能扩展;多年来形成了大量优秀的web开发框架,并且在不断迭代;如目前优秀的全栈的django、框架flask,都继承了python简单、明确的风格,开发效率高、易维护,与自动化运维结合性好,python已经成为自动化运维平台领域的事实标准;众多大型网站均为Python开发,Youtube, Dropbox, 豆瓣。
基于大数据分析和深度学习而发展出来的人工智能本质上已经无法离开python的支持,目前世界优秀的人工智能学习框架如Google的TransorFlow 、FaceBook的PyTorch以及开源社区的神经网络库Karas等是用python实现的,甚至微软的CNTK(认知工具包)也完全支持Python,而且微软的Vscode都已经把Python作为第一级语言进行支持。
Python在与操作系统结合以及管理中非常密切,目前所有linux发行版中都带有python,且对于linux中相关的管理功能都有大量的模块可以使用,例如目前主流的自动化配置管理工具:SaltStack Ansible(目前是RedHat的)。目前在几乎所有互联网公司,自动化运维的标配就是python+Django/flask,另外,在虚拟化管理方面已经是事实标准的openstack就是python实现的,所以Python是所有运维人员的必备技能。
量化交易,金融分析,在金融工程领域,Python不但在用,且用的最多,而且重要性逐年提高。原因:作为动态语言的Python,语言结构清晰简单,库丰富,成熟稳定,科学计算和统计分析都很牛逼,生产效率远远高于c,c++,java,尤其擅长策略回测
Python相对于其它解释性语言最大的特点是其庞大而活跃的科学计算生态,在数据分析、交互、可视化方面有相当完善和优秀的库(python数据分析栈:Numpy Pandas Scipy Matplotlip Ipython), 并且还形成了自己独特的面向科学计算的Python发行版Anaconda,而且这几年一直在快速进化和完善,对传统的数据分析语言如R MATLAB SAS Stata形成了非常强的替代性。
PyQT, WxPython,TkInter
1.4.Python行业应用
2.编程语言简介和特点
编程语言主要从以下几个角度为进行分类,小编整理了一些Python学习资料,有需要的朋友可以点击免费领取编译型和解释型、静态语言和动态语言、强类型定义语言和弱类型定义语言,每个分类代表什么意思呢,我们一起来看一下。
2.1.编译和解释型语言的区别
CPU不能直接认识并执行我们写的语句,它只能认识机器语言(CPU指令集;二进制的形式);因此我们开发语言的Virtual Machine要将识别的开发语言转换成机器语言让CPU去执行;那么就有两种以下两种方式:
编译型 解释型 混合型 C Java Script Java C++ Python C# GO Ruby N/A Swift PHP N/A Ojbect-C Perl N/A 2.2.编译和解释型优缺点
编译型
解释型
2.3.静态和动态语言
通常我们所说的动态语言、静态语言是指动态类型语言和静态类型语言。
动态类型语言是指在运行期间才去做数据类型检查的语言,也就是说,在用动态类型的语言编程时,永远也不用给任何变量指定数据类型,该语言会在你第一次赋值给变量时,在内部将数据类型记录下来。Python和Ruby就是一种典型的动态类型语言,其他的各种脚本语言如VBScript也多少属于动态类型语言。
静态类型语言与动态类型语言刚好相反,它的数据类型是在编译其间检查的,也就是说在写程序时要声明所有变量的数据类型,C/C++是静态类型语言的典型代表,其他的静态类型语言还有C#、JAVA等。
2.4.强类型和弱类型定义语言
强类型定义语言在速度上可能略逊色于弱类型定义语言,但是强类型定义语言带来的严谨性能够有效的避免许多错误。另外,“这门语言是不是动态语言”与“这门语言是否类型安全”之间是完全没有联系的!
例如:
强制数据类型定义的语言。也就是说,一旦一个变量被指定了某个数据类型,如果不经过强制转换,那么它就永远是这个数据类型了。举个例子:如果你定义了一个整型变量a,那么程序根本不可能将a当作字符串类型处理。强类型定义语言是类型安全的语言。
数据类型可以被忽略的语言。它与强类型定义语言相反, 一个变量可以赋不同数据类型的值。
通过上面这些介绍,我们可以得出,python是一门动态解释性的强类型定义语言。
3.What is Python?
3.1.Python哲学
Python开发者的哲学是“用一种方法,最好是只有一种方法来做一件事”。在设计Python语言时,如果面临多种选择,Python开发者一般会拒绝花俏的语法,而选择明确没有或者很少有歧义的语法。小编整理了一些Python学习资料,有需要的朋友可以点击免费领取这些准则被称为“Python格言”。在Python解释器内运行import this可以获得完整的列表。
>>> import this The Zen of Python, by Tim Peters Beautiful is better than ugly. Explicit is better than implicit. Simple is better than complex. Complex is better than complicated. Flat is better than nested. Sparse is better than dense. Readability counts. Special cases aren't special enough to break the rules. Although practicality beats purity. Errors should never pass silently. Unless explicitly silenced. ...... ......
语法非常的简短干练,没有一点多余的语法结构。
python对格式进行强制的限制;将格式整齐划一,就感觉在写诗一样优雅美丽;
在python的设计哲学中:要实现任何一件事情,都应该有一种并且我们认为是最好的一种方式去实现。没有像Perl语言那样花哨,(魔法语言),几乎就是不去调试,你不知道这段代码的逻辑。(几乎5个Perl开发,写出一个功能,就有5种写法出来。不利于团队协作)
3.2.Python优缺点
优点
特别适合初学者学Python,不但入门容易,而且将来深入下去,可以编写那些非常非常复杂的程序。
Python有非常强大的第三方库,基本上你想通过计算机实现任何功能,Python官方库里都有相应的模块进行支持,直接下载调用后,在基础库的基础上再进行开发,大大降低开发周期,避免重复造轮子。
当你用Python语言编写程序的时候,你无需考虑诸如如何管理你的程序使用的内存一类的底层细节
由于它的开源本质,Python已经被移植在许多平台上(经过改动使它能够工 作在不同平台上)。如果你小心地避免使用依赖于系统的特性,那么你的所有Python程序无需修改就几乎可以在市场上所有的系统平台上运行
如果你需要你的一段关键代码运行得更快或者希望某些算法不公开,你可以把你的部分程序用C或C++编写,然后在你的Python程序中使用它们。
你可以把Python嵌入你的C/C++程序,从而向你的程序用户提供脚本功能。
缺点
Python 的运行速度相比C语言确实慢很多,跟JAVA相比也要慢一些,因此这也是很多所谓的大牛不屑于使用Python的主要原因,但其实这里所指的运行速度慢在大多数情况下用户是无法直接感知到的,必须借助测试工具才能体现出来,比如你用C运一个程序花了0.01s,用Python是0.1s,这样C语言直接比Python快了10倍,算是非常夸张了,但是你是无法直接通过肉眼感知的,因为一个正常人所能感知的时间最小单位是0.15-0.4s左右,哈哈。其实在大多数情况下Python已经完全可以满足你对程序速度的要求,除非你要写对速度要求极高的搜索引擎等,这种情况下,当然还是建议你用C去实现的。
因为PYTHON是解释性语言,它的源码都是以名文形式存放的,不过我不认为这算是一个缺点,如果你的项目要求源代码必须是加密的,那你一开始就不应该用Python来去实现。
这是Python被人诟病最多的一个缺点,GIL即全局解释器锁(Global Interpreter Lock),是计算机程序设计语言解释器用于同步线程的工具,使得任何时刻仅有一个线程在执行,Python的线程是操作系统的原生线程。在Linux上为pthread,在Windows上为Win thread,完全由操作系统调度线程的执行。一个python解释器进程内有一条主线程,以及多条用户程序的执行线程。即使在多核CPU平台上,由于GIL的存在,所以禁止多线程的并行执行。
3.3.Python解释器
当我们编写Python代码时,我们得到的是一个包含Python代码的以.py为扩展名的文本文件。要运行代码,就需要Python解释器去执行.py文件。
由于整个Python语言从规范到解释器都是开源的,所以理论上,只要水平够高,任何人都可以编写Python解释器来执行Python代码(当然难度很大)。事实上,确实存在多种Python解释器。
当我们从Python官方网站下载并安装好Python 2.7后,我们就直接获得了一个官方版本的解释器:CPython。这个解释器是用C语言开发的,所以叫CPython。在命令行下运行python就是启动CPython解释器。
CPython是使用最广的Python解释器。教程的所有代码也都在CPython下执行。
IPython是基于CPython之上的一个交互式解释器,也就是说,IPython只是在交互方式上有所增强,但是执行Python代码的功能和CPython是完全一样的。好比很多国产浏览器虽然外观不同,但内核其实都是调用了IE。
CPython用>>>作为提示符,而IPython用In [序号]:作为提示符。
PyPy是另一个Python解释器,它的目标是执行速度。PyPy采用JIT技术,对Python代码进行动态编译(注意不是解释),所以可以显著提高Python代码的执行速度。
绝大部分Python代码都可以在PyPy下运行,但是PyPy和CPython有一些是不同的,这就导致相同的Python代码在两种解释器下执行可能会有不同的结果。如果你的代码要放到PyPy下执行,就需要了解PyPy和CPython的不同点。
Jython是运行在Java平台上的Python解释器,可以直接把Python代码编译成Java字节码执行。
IronPython和Jython类似,只不过IronPython是运行在微软.Net平台上的Python解释器,可以直接把Python代码编译成.Net的字节码。
4.Python2 or 3?
What are the differences?
In summary : Python 2.x is legacy, Python 3.x is the present and future of the language
https://wiki.python.org/moin/Python2orPython3
Python 3.0 was released in 2008. The final 2.x version 2.7 release came out in mid-2010, with a statement of extended support for this end-of-life release. The 2.x branch will see no new major releases after that. 3.x is under active development and has already seen over five years of stable releases, including version 3.3 in 2012, 3.4 in 2014, 3.5 in 2015, and 3.6 in 2016. This means that all recent standard library improvements, for example, are only available by default in Python 3.x.
Guido van Rossum (the original creator of the Python language) decided to clean up Python 2.x properly, with less regard for backwards compatibility than is the case for new releases in the 2.x range. The most drastic improvement is the better Unicode support (with all text strings being Unicode by default) as well as saner bytes/Unicode separation.
Besides, several aspects of the core language (such as print and exec being statements, integers using floor division) have been adjusted to be easier for newcomers to learn and to be more consistent with the rest of the language, and old cruft has been removed (for example, all classes are now new-style, "range()" returns a memory efficient iterable, not a list as in 2.x).
4.1.性能
Py3.0运行 pystone benchmark的速度比Py2.5慢30%。Guido认Py3.0有极大的优化空间,在字符串和整形操作上可以取得很好的优化结果。
4.2.编码
Py3.x: ALL IS UNICODE NOW
4.3.语法
The statement has been replaced with a print() function, with keyword arguments to replace most of the special syntax of the old statement (PEP 3105). Examples:
2.X: print "The answer is", 2*2 3.X: print("The answer is", 2*2) 2.X: print x, # 使用逗号结尾禁止换行 3.X: print(x, end=" ") # 使用空格代替换行 2.X: print # 输出新行 3.X: print() # 输出新行 2.X: print >>sys.stderr, "fatal error" 3.X: print("fatal error", file=sys.stderr) 2.X: print (x, y) # 输出repr((x, y)) 3.X: print((x, y)) # 不同于print(x, y)!
4.4.Rename module
Old Name New Name _winreg winreg ConfigParser configparser copy_reg copyreg Queue queue SocketServer socketserver markupbase _markupbase repr reprlib test.test_support test.support 5.Python安装
官方网站:https://www.python.org/downloads
官方文档:https://docs.python.org/2.7/
5.1.windows
图片来自网络
5.2.Linux、Mac
linux mac平台默认就安装python,如果版本要求达不到,需要重装
# tar -zxvf Python-2.7.13-source.tgz # cd Python-2.7.13 # ./configure --prefix=/${PYTHON_HOME}/python2.7.13 # make # make install #调整系统环境变量为python2.7.13 # vi /etc/profile export PATH=/${PYTHON_HOME}/python2.7.13/bin:$PATH
6.初识Python
6.1.标志性开篇:hello world程序
据传说每一个程序员的第一个程序:Hello World!,从此他们就走上了一条不归路...
6.1.1.解释器执行
$ python Python 2.7.10 (default, Jun 1 2017, 11:18:18) [GCC 4.4.7 20120313 (Red Hat 4.4.7-18)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> print('Hello World!') Hello World!
6.1.2.文件执行
除了直接调用python自带的交互器运行代码,,还可以把程序写在文件里;linux 下创建一个文件叫hello.py,并输入
print("Hello World!")
然后执行命令:python hello.py ,输出
$ python hello_world.py Hello World!
指定解释器
上一步中执行 python hello.py 时,明确的指出 hello.py 脚本由 python 解释器来执行。
如果想要类似于执行shell脚本一样执行python脚本,例: ./hello.py ,那么就需要在 hello.py 文件的头部指定解释器,如下(执行之前记得授权):
$ cat hello_world.py #!/bin/env python print("Hello World!") $ chmod +x hello_world.py $ ./hello_world.py Hello World!
如此一来,执行: ./hello.py 即可。
7.开发规范
PEP8英文:http://jython.cn/dev/peps/pep-0008/
PEP8中文:https://python.freelycode.com/contribution/detail/47
7.1.编程风格
7.1.1.缩进统一
7.1.1.1.以下代码,是否能执行,那个先被执行?
$ vim indent.py #!/bin/env python def main(): print 'Hello World!' print 'test code!' main() $ python indent.py
7.1.1.2.尝试以下代码是否可以?
$ vim indent.py #!/bin/env python def main(): print 'Hello World!' print 'test code!' main()
7.1.2.变量规范
>>> 3name = 123 File "", line 1 3name = 123 ^ SyntaxError: invalid syntax >>> this is = 'here!' File " ", line 1 this is = 'here!' ^ SyntaxError: invalid syntax
以上是错误的示例
8.变量赋值
计算机科学中不能完全以数学思维方式来思考问题。如变量的赋值实现就和自然科学中数学是不一样的。
以下代码中 x 和 y的结果?
$ cat evaluation.py #!/bin/env python x = 123 y = x x = 456 print 'x: ' ,x print 'y: ' ,y
赋值分析
图片来自网络
9.字符编码
9.1.ASCII
ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。
2.x版本python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)
图片来自网络
显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode
9.2.Unicode
Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,
注:此处说的的是最少2个字节,可能更多
存储数据要用两个两个字节来表示,主要用于存储中文、韩文等编码格式,但由于字母本身就可以用一个字节来表示,所以都在Unicode的编码下,对于字母型数据,会造成很大的浪费
9.3.UTF-8
UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...
为解决Unicode字母型数据造成浪费的问题,字母用一个字节表示,中文等用三个字节表示(灵活可变的长度应对不用的类型的数据)
所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:
# vim hello_world.py #!/bin/env python print('厉害了,word哥') # python hello_world.py File "hello_world.py", line 2 SyntaxError: Non-ASCII character '\\xe5' in file hello_world.py on line 2, but no encoding declared; see http://www.python.org/peps/pep-0263.html for details
应该显示的告诉python解释器,用什么编码来执行源代码:
# vim hello_world.py
#!/bin/env python
# _*_ coding:utf-8 _*_
print('厉害了,word哥')
10.注释
# 被注释内容
‘’‘被注释的代码块’‘’
"""被注释的代码块 """
11.用户输入
11.1.格式化打印用户的结果
要求用户输入基本信息后,格式化打印
11.1.1.通过拼接+号的方法实现格式化打印输出,该方法不是最佳的方案,因为每次拼接在内存中需要开辟一块内存空间用于存放拼接的数据,so正确的方法参考一下方法
names = raw_input('Enter your name? ') age = str(input('Enter your age? ')) job = raw_input('Enter your job? ') salary = raw_input('Enter your salary? ') info = """---Personal information of """ + names + """ --------------- names :""" + names + """ age :""" + age + """ job :""" + job + """ salary :""" + salary print info
11.1.2.通过占位符的方式,将格式化的结果打印。
# vim raw_input.py #!/bin/env python #_*_ coding:utf-8 _*_ __author__ = "Bruce.Liu" name = raw_input('Please input your name:') age = raw_input('Age: ') job = raw_input('Job: ') print ''' Personal information of %s: Name: %s Age : %s Job : %s ''' % (name, name, age, job)
打印结果,验证
# python raw_input.py Please input your name:Bruce.Liu Age: 27 Job: IT Personal information of Bruce.Liu: Name: Bruce.Liu Age : 27 Job : IT
11.2.3..format方法实现格式化打印
print ''' ---Personal information of {_name} --------------- names : {_name} age : {_age} job : {_job} salary : {_salary} '''.format(_name=names, _age=age, _job=job, _salary=salary )
12.Module简介
Python的强大之处在于他有非常丰富和强大的标准库和第三方库,几乎你想实现的任何功能都有相应的Python库支持,以后的课程中会深入讲解常用到的各种库,现在,我们先来象征性的学2个简单的。
12.1.Module分类
Python有大量的模块,从而使得开发Python程序非常简洁。类库有包括三中:
12.2.Module实践
12.2.1.SYS Module
$ vim sys_module.py #!/bin/env python # _*_ coding: utf-8 _*_ import sys print(sys.argv) $ python sys_module.py args1 ['sys_module.py', 'args1']
12.2.2.OS Module
$ cat os_module.py #!/bin/env python # _*_ coding:utf-8 _*_ import os os.system("df -h")
$ cat exec_cmd.py #!/bin/env python # _*_ coding:utf-8 _*_ import os,sys #print sys.argv, ''.join(sys.argv[1]) os.system(''.join(sys.argv[1:])) $ python exec_cmd.py free total used free shared buffers cached Mem: 49374032 34720292 14653740 564 775392 27056956 -/+ buffers/cache: 6887944 42486088 Swap: 8388600 3104 8385496
12.2.3.Custom Module
默认的Cpython解释器,不提供tab键自动补全功能,so Now!我们加一个这种功能;让我们的学习更加简单
12.2.3.1.找到python全局环境变量目录,方便我们将来在任何一个路径下Cpython都能识别到自定义的Module
>>> import sys >>> sys.path ['', '/usr/local/python/lib/python2.7/site-packages/pip-9.0.1-py2.7.egg', '/usr/local/python/lib/python27.zip', '/usr/local/python/lib/python2.7', '/usr/local/python/lib/python2.7/plat-linux2', '/usr/local/python/lib/python2.7/lib-tk', '/usr/local/python/lib/python2.7/lib-old', '/usr/local/python/lib/python2.7/lib-dynload', '/usr/local/python/lib/python2.7/site-packages']
12.2.3.2.在Python默认搜索的路径下创建Module
$ cd /usr/local/python/lib/python2.7/site-packages $ vim tab.py #!/bin/env python try: import readline except ImportError: print ("Module readline not available.") else: import rlcompleter readline.parse_and_bind("tab: complete")
12.2.3.3.导入该Module
$ python Python 2.7.10 (default, Jun 1 2017, 11:18:18) [GCC 4.4.7 20120313 (Red Hat 4.4.7-18)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> import tab
sys.path会打印Python全局环境变量目录,一般都放在一个叫 Python/2.7/site-packages 目录下,这个目录在不同的OS里放的位置不一样,用 print(sys.path) 可以查看python环境变量列表。
13.pyc文件
pyc是一种二进制文件,是由py文件经过编译后,生成的文件,是一种byte code,py文件变成pyc文件后,加载的速度有所提高,而且pyc是一种跨平台的字节码,是由python的虚拟机来执行的,这个是类似于JAVA或者.NET的虚拟机的概念。pyc的内容,是跟python的版本相关的,不同版本编译后的pyc文件是不同的,2.5编译的pyc文件,2.4版本的 python是无法执行的。
13.1.解释型语言和编译型语言
计算机是不能够识别高级语言的,所以当我们运行一个高级语言程序的时候,就需要一个“翻译机”来从事把高级语言转变成计算机能读懂的机器语言的过程。这个过程分成两类,小编整理了一些Python学习资料,有需要的朋友可以点击免费领取第一种是编译,第二种是解释。
编译型语言在程序执行之前,先会通过编译器对程序执行一个编译的过程,把程序转变成机器语言。运行时就不需要翻译,而直接执行就可以了。最典型的例子就是C语言。
解释型语言就没有这个编译的过程,而是在程序运行的时候,通过解释器对程序逐行作出解释,然后直接运行,最典型的例子是Ruby。
通过以上的例子,我们可以来总结一下解释型语言和编译型语言的优缺点,因为编译型语言在程序运行之前就已经对程序做出了“翻译”,所以在运行时就少掉了“翻译”的过程,所以效率比较高。但是我们也不能一概而论,一些解释型语言也可以通过解释器的优化来在对程序做出翻译时对整个程序做出优化,从而在效率上超过编译型语言。
此外,随着Java等基于虚拟机的语言的兴起,我们又不能把语言纯粹地分成解释型和编译型这两种。
用Java来举例,Java首先是通过编译器编译成字节码文件,然后在运行时通过解释器给解释成机器文件。所以我们说Java是一种先编译后解释的语言。
13.2.Python到底是什么
其实Python和Java/C#一样,也是一门基于虚拟机的语言,我们先来从表面上简单地了解一下Python程序的运行过程吧。
当我们在命令行中输入python hello.py时,其实是激活了Python的“解释器”,告诉“解释器”:你要开始工作了。可是在“解释”之前,其实执行的第一项工作和Java一样,是编译。
熟悉Java的同学可以想一下我们在命令行中如何执行一个Java的程序:
javac hello.java java hello
只是我们在用Eclipse之类的IDE时,将这两部给融合成了一部而已。其实Python也一样,当我们执行python hello.py时,他也一样执行了这么一个过程,所以我们应该这样来描述Python,Python是一门先编译后解释的语言。
13.3.简述Python执行过程
图片来自网络
与java类似,Python将.py编译为字节码,然后通过虚拟机执行。编译过程与虚拟机执行过程均在python25.dll中。Python虚拟机比java更抽象,离底层更远。
编译过程不仅生成字节码,还要包含常量、变量、占用栈的空间等,Pyton中编译过程生成code对象PyCodeObject。将PyCodeObject写入二进制文件,即.pyc。
我们在硬盘上看到的pyc自然不必多说,而其实PyCodeObject则是Python编译器真正编译成的结果。我们先简单知道就可以了,继续向下看。
当python程序运行时,编译的结果则是保存在位于内存中的PyCodeObject中,当Python程序运行结束时,Python解释器则将PyCodeObject写回到pyc文件中。
当python程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如果找到,则直接载入,否则就重复上面的过程。
所以我们应该这样来定位PyCodeObject和pyc文件,我们说pyc文件其实是PyCodeObject的一种持久化保存方式。
14.数据类型简介
Python有五个标准的数据类型:
14.1.Number(数字)
数学复习: http://www.guokr.com/post/432219/
Python支持四种不同的数字类型:
14.1.1.int(有符号整型)
>>> var1 = 1 >>> print type(var)>>> del var
14.1.2.long(长整型)
>>> var = 2 ** 63 >>> type(var)
14.1.3.float(浮点型)
图片来自网络
>>> var2 = 3.1415926 >>> print type(var2)
14.1.4.complex(复数)
>>> aComplex = -8.333-1.47j >>> aComplex.real -8.333 >>> aComplex.imag -1.47
14.2.Bool(布尔值)
>>> bool(0) False >>> bool(-1) True >>> a = [1,2,3] >>> b = [] >>> bool(a) True >>> bool(b) False
14.3.String(字符串)
python中的字符串在C语言中体现为是一个字符数组,每次创建字符串时候需要在内存中开辟一块连续的空,并且一旦需要修改字符串的话,就需要再次开辟空间,万恶的+号每出现一次就会在内从中重新开辟一块空间。
>>> sehai = "Hello " + "World"
尽量用一下方式:字符串格式化
14.3.1.字符型占位符示例
>>> name = "Bruce.Liu" >>> print "i am is %s" % name i am is Bruce.Liu
如果有多个转换说明符时,必须元组的形势存在。否则则抛异常
>>> format = "Hello. %s. %s enough for ya?" >>> values = ('world','Hot') >>> print format % values Hello. world. Hot enough for ya?
14.3.2.整数型占位符示例
>>> format = '100 + 250 = %d' % 350 >>> print format 100 + 250 = 350
14.3.3.浮点型占位符示例
14.3.3.1.宽度和精度
>>> print 'Pi with three decimals: %10.3f' %(3.1415926) Pi with three decimals: 3.142
14.3.3.2.对齐填充
>>> print '%010.2f' % 3.1415 0000003.14
14.3.3.3.右填充
>>> '%-10.2f' % 3.1415 '3.14 '
14.4.List(列表)
>>> l_res = ['HanXiang','ShenZhen','IT'] >>> l_res[0] 'HanXiang'
14.5.Tuple(元组)
>>> tuple_res = ('SQL result','...') >>> tuple_res[0] 'SQL result'
14.6.Dictionary(字典)
>>> emp_info = {'name':'Bruce','job':'IT'} >>> emp_info['name'] 'Bruce'
15.作业