一:Python来源
python的创始人为吉多·范罗苏姆(Guido van Rossum)。1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承。
由上图可见,Python 近年来一直排行使用计算机语言的前五位,也反映出Python应用越来越广泛并且也逐渐得到业内的认可!!!
Python可以应用于众多领域,如:数据分析、组件集成、网络服务、图像处理、数值计算和科学计算等众多领域。目前业内几乎所有大中型互联网企业都在使用Python,如:Youtube、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、腾讯、汽车之家、美团等。互联网公司广泛使用Python来做的事一般有:自动化运维、自动化测试、大数据分析、爬虫、Web 等。
二:为什么是Python而不是其他语言?
C 和 Python、Java、C#等
C语言: 代码编译得到 机器码 ,机器码在处理器上直接执行,每一条指令控制CPU工作
其他语言: 代码编译得到 字节码 ,虚拟机执行字节码并转换成机器码再后在处理器上执行
Python 和 C Python这门语言是由C开发而来
对于使用:Python的类库齐全并且使用简洁,如果要实现同样的功能,Python 10行代码可以解决,C可能就需要100行甚至更多.
对于速度:Python的运行速度相较与C,绝逼是慢了
Python 和 Java、C#等
对于使用:Linux原装Python,其他语言没有;以上几门语言都有非常丰富的类库支持
对于速度:Python在速度上可能稍显逊色
所以,Python和其他语言没有什么本质区别,其他区别在于:擅长某领域、人才丰富、先入为主。
三: 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 的应用领域
web 开发:
DjangopyramidTornadoBottleFlaskWebPy
网络编程:
twistedRequestsscrapyparamiko
科学运算:
Scipypandaslpython
GUI图形开发
WXpythonpyqtkivy
运维自动化:
openstackslatstackansible腾讯蓝鲸
五:运维人员会开发能做些什么:
1. 帮助公司开发各种自动化工具,定制开发各种开源软件
2. 帮助评估和优化业务技术架构
3.开发公司的内部办公系统,CRM,网站等
4. 做个全栈工程师,全栈是指什么都能做的样子,自己就可以完成一个小项目
一:Python的安装
windows 安装:
1、
下载地址
https:
/
/
www.python.org
/
downloads
/
2
、安装
默认安装路径:C:python35
3
、配置环境变量
【右键计算机】
-
-
》【属性】
-
-
》【高级系统设置】
-
-
》【高级】
-
-
》【环境变量】
-
-
》【在第二个内容框中找到 变量名为Path 的一行,双击】
-
-
> 【Python安装目录追加到变值值中,用 ; 分割】
如:原来的值;C:python35,切记前面有分号
linux 安装:
无需安装,原装Python环境
ps:如果自带2.6,请更新至3.5
更新Python
windows 下面 卸载重新安装即可
Linux 下面:
Linux的yum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python
查看默认Python版本 python -V 1、安装gcc,用于编译Python源码 yum install gcc 2、下载源码包,https://www.python.org/ftp/python/ 3、解压并进入源码文件 4、编译安装 ./configure make all make install 5、查看版本 /usr/local/bin/python3.5 -V 6、修改默认Python版本 mv /usr/bin/python /usr/bin/python2.6 ln -s /usr/local/bin/python3.5 /usr/bin/python 7、防止yum执行异常,修改yum使用的Python版本 vi /usr/bin/yum 将头部 #!/usr/bin/python 修改为 #!/usr/bin/python2.6
一:Python的第一程序:
1.1: windows 下面:
print("hello world!!!")
1.2:Linux 下面:
### vim helloworld.py
1 #!/usr/bin/env python 2 print ("hello world!!!!")
二:Python的变量
2.1 声明一个变量
###vim name.py
1 #!/usr/bin/env python 2 name = "flyfish" 3 print ("my name is",flyfish)
2.2 变量的声明规则
变量定义的规则:
变量名只能是 字母、数字或下划线的任意组合
变量名的第一个字符不能是数字
以下关键字不能声明为变量名
['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']
### vim myname.py
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 name = "flyfish" 5 name2 = name 6 print("my name is",name,name2) 7 name = 'liyang' 8 print("my name is",name,name2)
三: 字符编码与字符串拼接
3.1 字符编码:
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、GB2312、GBK 到GB18030,这些编码方法是向下兼容的,即同一个字符在这些方案中总是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文可以统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB2312、GBK到GB18030都属于双字节字符集 (DBCS)。
有的中文Windows的缺省内码还是GBK,可以通过GB18030升级包升级到GB18030。不过GB18030相对GBK增加的字符,普通人是很难用到的,通常我们还是用GBK指代中文Windows内码。
显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode
Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,
注:此处说的的是最少2个字节,可能更多
UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...
所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:
报错:ascii码无法表示中文
3.2 代码:
1 #!/usr/bin/env python 2 3 # -*- coding: utf-8 -*- 4 5 # Author:FlyFish 6 7 print("你好,世界!!!!")
3.3 python 代码的注释:
单行注视:# 被注释内容 多行注释:""" 被注释内容 """
3.4 用户输入格式化输出字符串拼接
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 name = input("name:") 5 age = input("age:") 6 job = input("job:") 7 info = ''' 8 ------info of %s ----- 9 name:%s 10 age:%s 11 job:%s 12 ''' % (name,name,age,job) 13 print(info)
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 5 name = input("name:") 6 age = input("age:") 7 job = input("job:") 8 info = ''' 9 ------info of {_name} ----- 10 name:{_name} 11 age:{_age} 12 job:{_job} 13 ''' .format(_name=name, 14 _age=age, 15 _job=job 16 ) 17 print(info)
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 name = input("name:") 5 age = input("age:") 6 job = input("job:") 7 info = ''' 8 ------info of {0}----- 9 name:{0} 10 age:{1} 11 job:{2} 12 ''' .format(name, 13 age, 14 job 15 ) 16 print(info)
3.5 Python的用户输入:
Python的输入
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 5 #import getpass 6 7 _username = "zhangyy" 8 _password = "abc123" 9 10 username = input("username:") 11 password = input("password:") ### password = getpass.getpass("password:") 12 13 if _username == username and _password == password: 14 print("Welcom user {name} login".format(name=username)) 15 else: 16 print("Invalid username or password ")
四:if....else 循环:
在程序里设定好你的年龄,然后启动程序让用户猜测,用户输入后,根据他的输入提示用户输入的是否正确,如果错误,提示是猜大了还是小了
注释:
外层变量,可以被内层代码使用
内层变量,不应被外层代码使用
1 #!/usr/bin/env python 2 3 # -*- coding: utf-8 -*- 4 5 # Author:FlyFish 6 7 age_of_zhangyy = 26 8 9 guess_age = int(input("guess zhangyyy age:")) 10 11 if guess_age == age_of_zhangyy: 12 print("yes,yo go it") 13 elif guess_age > age_of_zhangyy: 14 print("think smaller...") 15 else: 16 print("think bigger")
五:while的循环
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 5 count = 0 6 7 while True: 8 print("count",count) 9 count = count + 1
5.1 关于猜年龄的游戏
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 # Author:FlyFish 4 age_of_zhangyy = 26 5 count = 0 6 while True: 7 if count == 3: 8 break 9 guess_age = int(input("guess zhangyyy age:")) 10 if guess_age == age_of_zhangyy: 11 print("yes,yo go it") 12 break 13 elif guess_age > age_of_zhangyy: 14 print("think smaller...") 15 else: 16 print("think bigger") 17 count+=1
1 #!/usr/bin/env python 2 3 # -*- coding: utf-8 -*- 4 5 # Author:FlyFish 6 7 age_of_zhangyy = 26 8 count = 0 9 while count<3: 10 11 guess_age = int(input("guess zhangyyy age:")) 12 13 if guess_age == age_of_zhangyy: 14 print("yes,yo go it") 15 break 16 elif guess_age > age_of_zhangyy: 17 print("think smaller...") 18 else: 19 print("think bigger") 20 count+=1 21 22 if count ==3: 23 countine_confirm = input("do you want to guessing....") 24 if countine_confirm !='n': 25 count ==0 26 27 else: 28 print("you have tried too many times..fuck off")