python开发之路-第一章
python 介绍
1989年的圣诞节吉多·范罗苏姆为了在阿姆斯特丹打发时间开发的一门编程语言,他估计都没有想到16年后的今天 python已经广为熟知,并应用于全世界的巨头的互联网公司中
目前python主流应用场景有:自动化运维、自动化测试、大数据分析、爬虫、Web 等
看到这里你肯定会是这个表情, 闲着无聊都能干个语言出来。牛!
一,python与C
python是用C语言编写的,他的运行速度比不上C,但我想说的是, C运行一个程序花了 0.001秒 python花了0.01秒 这样看来也无可厚非了。
现在主流使用的是使用Cpython来实现,CPython实现会将源文件(py文件)转换成字节码文件(pyc文件),然后运行在Python虚拟机上,这是导致比C慢的根本原因。
python中的字符串在C中是以单字符组合来表示的
下文会陆续补充。
二,python版本与环境部署
现在的主流版本还是python2.7 所以本文的环境都是python2.7
Windows部署,需要下载一个python程序,将python的安装路径粘贴到windows的环境变量中,这样在cmd中就可以运行python了,然后准备一个nodepad++就可以在windows上运行python了,另外还可以选择pythoncharm 等软件。
linux部署,centos 7 和ubutu自带python2.7,装个虚拟就行。
三,我的第一个python脚本
1 #!/usr/bin/env python #声明解释器使用python 和shell一样 大家都懂得 2 # -*- coding:utf-8 -*-#声明要使用的编码 因为utf-8支持中文并且会合理利用内存的空间 3 print "hello world" 4 #执行 5 #hello world
1,万分惊喜的运行了我第一个python脚本,我知道我的路还很长。
2,python的执行流程
说要流程先说说什么是编译语言什么是解释语言吧。
python是一门高级语言,计算机是无法识别高级语言的,这也是c的是最大区别之处。所以当我们运行一个高级语言程序的时候,就需要一个“翻译机”来从事把高级语言转变成计算机能读懂的机器语言的过程。这个过程分成两类,第一种是编译,第二种是解释。
编译型语言在程序执行之前,先会通过编译器对程序执行一个编译的过程,把程序转变成机器语言。运行时就不需要翻译,而直接执行就可以了。最典型的例子就是C语言。而解释型语言就没有这个编译的过程,而是在程序运行的时候,通过解释器对程序逐行作出解释,然后直接运行,最典型的例子是Ruby。
通 过以上的例子,我们可以来总结一下解释型语言和编译型语言的优缺点,因为编译型语言在程序运行之前就已经对程序做出了“翻译”,所以在运行时就少掉了“翻 译”的过程,所以效率比较高。但是我们也不能一概而论,一些解释型语言也可以通过解释器的优化来在对程序做出翻译时对整个程序做出优化,从而在效率上超过 编译型语言。
此外,随着Java等基于虚拟机的语言的兴起,我们又不能把语言纯粹地分成解释型和编译型这两种。
用Java来举例,Java首先是通过编译器编译成字节码文件,然后在运行时通过解释器给解释成机器文件。所以我们说Java是一种先编译后解释的语言。
再换成C#,C#首先是通过编译器将C#文件编译成IL文件,然后在通过CLR将IL文件编译成机器文件。所以我们说C#是一门纯编译语言,但是C#是一门需要二次编译的语言。同理也可等效运用到基于.NET平台上的其他语言。
其实Python和Java/C#一样,也是一门基于虚拟机的语言,我们先来从表面上简单地了解一下Python程序的运行过程吧。
当我们在命令行中输入python hello.py时,其实是激活了Python的“解释器”,告诉“解释器”:你要开始工作了。可是在“解释”之前,其实执行的第一项工作和Java一样,是编译。
只是我们在用Eclipse之类的IDE时,将这两部给融合成了一部而已。其实Python也一样,当我们执行python hello.py时,他也一样执行了这么一个过程,所以我们应该这样来描述Python,Python是一门先编译后解释的语言。
在说运行过程之前,我们先来说两个概念,PyCodeObject和pyc文件。我们在硬盘上看到的pyc自然不必多说,而其实PyCodeObject则是Python编译器真正编译成的结果。我们先简单知道就可以了,继续向下看。
当python程序运行时,编译的结果则是保存在位于内存中的PyCodeObject中,当Python程序运行结束时,Python解释器则将PyCodeObject写回到pyc文件中。
当python程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如果找到,则直接载入,否则就重复上面的过程。
所以我们应该这样来定位PyCodeObject和pyc文件,我们说pyc文件其实是PyCodeObject的一种持久化保存方式。
运行流程 1,加载内存 2,词法分析 3,语法分析 4,编译 5,字节码 6,机器码
四,编码介绍
python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ASCII)
ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。
对于中文,使用utf-8对于内存的使用: 分别对于英文字符和中文字符的存储是分开的 英文使用8位 中文使用24位.这样可以灵活并充分利用内存空间
所以在每一个.py文件的声明中都需要加上:
# -*- coding:utf-8 -*- #使用utf-8的字符集
# coding:utf-8
五,python的语法
1,变量
1 name = "wenqiang" #这样就定义了变量名name指向内存中存储的字符串"wenqiang" 2 print name
>>>wenqiang
2,输入
1 name = raw_input("Please inter your name:")#使用raw_input来将变量赋值,并且("")中可以提示 2 print "hello",name #下面是输出结果
#加密输入 1 import getpass #加密输入需要引用内置的库文件 getpass 2 name = raw_input("Please inter your name:") 3 pwd = getpass.getpass("please inter your password:") 4 if name == "wenqiang" and pwd == "123":#如果输入的name为wenqiang pwd为123 5 print "welcome back",name
3,注释
一名负责人的程序员一定要会在他的程序中添加上脚本的注释和每一个功能的注释,意义有两个 1.当别人看你的脚本时能够清晰易懂,快速理解你的语句中想表达的意思,提高可读性。2,养成良好的编程习惯,是成为一名优秀的程序员的必要条件。
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 #这是一个系统搜集的监控脚本 4 name = raw_input("") #这是一句交互的输入指令,你输入的结果会赋值给变量"name" 5 6 7 """ #使用"""开头 ,"""结尾是进行多行注释 8 name = 1 9 name 1 = name 10 print name 1 11 """
六,数据类型
1 name = {"1","2"} 2 type(name) 3 <type 'set'>
七,参数
1,占位符
1 >>> name = 'im %s .age %d' % ('wq',123)# "%s"(代表字符串) "%d"(代表数字) 2 >>> name 3 'im wq .age 123'
1 >>> name = "sss %s %d " #另一种参数赋值方法 2 >>> name %("wq",123) 3 'sss wq 123 '
1 name = "sss {0} ,sss {1}" #另一种赋值方法 2 name.format("wenqiang",18) 3 'sss wenqiang ,sss 18'
八,索引(下标)
1 >>> name="wenqiang" 2 >>> name[0:5]#显示wenqiang这个字符串下标0~5(不包括5的字符) 3 'wenqi' 4 >>> name[0:6] 5 'wenqia' 6 >>> len(name) #打印这个字符串的长度 7 8
1 >>> name=" wenqiang " 2 >>> name 3 ' wenqiang ' 4 >>> print name.strip() 5 wenqiang 6 >>> name 7 ' wenqiang ' 8 >>> print name.lstrip() 9 wenqiang 10 >>> print name.rstrip() 11 wenqiang
1 >>> name="wenqiang" 2 >>> print name.split("qi") #split方法将变量的值以“qi”分割 变成了一个列表 但是不再包含“qi” 3 ['wen', 'ang']
1 >>> name 2 'wenqiang' 3 >>> name =name.split("qi") #将name这个变量变成一个列表 4 >>> name 5 ['wen', 'ang'] 6 >>> name.append("hello")#在列表name中增加一个字符串 7 >>> name 8 ['wen', 'ang', 'hello']
1 >>> name 2 ['wen', 'ang', 'hello'] 3 >>> del name[0] #del 是一个全局的方法,这里我们使用它来删除name这个列表中 下标为0的字符串,也就是第一个字符串 4 >>> name 5 ['ang', 'hello']
1 >>> name 2 ['ang', 'hello'] 3 >>> "_".join(name)#将_下划线加入到列表name中间,并且使其成为一个字符串 4 'ang_hello' 5 >>> name = "_".join(name) 6 >>> name 7 'ang_hello'
十四,循环
我们来写一个简单的循环脚本
1 #!/usr/bin/env python #声明解释器 2 # -*-coding:utf-8 -*- #声明编码 3 name_list = ["wenqiang","zhonghua","xiaobing"] 4 for i in name_list: 5 if i == "wenqiang": 6 print i 7 continue 8 if i == "zhonghua": 9 print i 10 else: #不管i是否指定值都返回 11 print i
执行结果为
十五,字典
1,创建字典
1 >>> person = {"wenqiang":18,"zhonghua":30,"xiaobing":20} 2 >>> person 3 {'wenqiang': 18, 'zhonghua': 30, 'xiaobing': 20}
2,取值
#!/usr/bin/env python # -*-coding:utf-8 -*- person = {'wenqiang': 18, 'zhonghua': 30, 'xiaobing': 20} for k,v in person.items(): print k print v