Python简介

  Python可以应用于众多领域,如:数据分析、组件集成、网络服务、图像处理、数值计算和科学计算等众多领域。目前业内几乎所有大中型互联网企业都在使用Python,如:Youtube、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、腾讯、汽车之家、美团等。互联网公司广泛使用Python来做的事一般有:自动化运维自动化测试大数据分析、爬虫、Web 等。

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,具有JIT(just In time)Compiler , 将Python的字节码字节码再编译成机器码。
    • RubyPython、Brython ...

代码常见的执行方式:

  (1)编译执行,在程序运行之前,通过编译器将代码转换为CPU指令(机器码),运行的时候就不需要翻译,可以直接执行这些指令,好处当然是非常快,一条多余的指令都没有;坏处则是难以支持许多动态特性。

  (2)解释执行,在程序运行时,解释一条,执行一条。也就是对每条语句在运行时用解释器去执行它相应的动作,好处是实现起来非常简单,也很容易添加新特性,坏处则是执行得非常慢,大部分CPU时间花在了解释器运行上面。

  (3)JIT编译,是动态编译(运行时编译)的特例,技术是两者的结合,首先让代码解释执行,同时收集信息,当发现某个代码或代码块运行得特别频繁时,会把这些代码认定为热点代码,在收集到足够信息的时候,(通过检查栈顶代码,或者计数器检测等)将这些热点代码动态编译成CPU指令,然后用CPU指令替代解释执行的过程,因为编译发生在马上要执行之前,所以叫做Just-In-Time Compiler。编译之后速度就是编译执行的速度了,自然比解释执行要快得多,所以运用JIT的PyPy要比CPython快不少。

  Python和Java、C#一样,是一门基于虚拟机的语言,在程序运行之前先编译成字节码,然后通过解释器解释执行。

  PyCodeObject是Python编译器真正编译成的结果,当程序运行时,编译的结果放在内存中的PyCodeObject中,当程序运行结束时,Python解释器将PyCodeObject写回到pyc文件中;

  当程序第二次执行时,会首先寻找pyc文件,判断pyc文件与py文件的修改时间,决定是否直接执行pyc文件。可以说pyc文件是PyCodeObject的一种持久化保存方式。

安装Python

  windows:

  1. 1、下载安装包
  2. https://www.python.org/downloads/
  3.  
  4. 2、安装
  5. 默认安装路径:C:\python27
  6.  
  7. 3、配置环境变量
  8. 【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> Python安装目录追加到变值值中,用 分割】
  9. 如:原来的值 ;C:\python27 切记前面有分号!!    

  Linux:

  1. 无需安装,原装Python环境
  2. ps:如果自带2.6,请更新至2.7

更新Python:

  Windows:

  1. 卸载重装即可

  Linux:

  1. Linuxyum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python
  2.  
  3. 查看默认Python版本
  4. python -V
  5.  
  6. 1、安装gcc,用于编译Python源码
  7. yum install gcc
  8. 2、下载源码包,https://www.python.org/ftp/python/
  9. 3、解压并进入源码文件
  10. 4、编译安装
  11. ./configure
  12. make all
  13. make install
  14. 5、查看版本
  15. /usr/local/bin/python2.7 -V
  16. 6、修改默认Python版本
  17. mv /usr/bin/python /usr/bin/python2.6
  18. ln -s /usr/local/bin/python2.7 /usr/bin/python
  19. 7、防止yum执行异常,修改yum使用的Python版本
  20. vi /usr/bin/yum
  21. 将头部 #!/usr/bin/python 修改为 #!/usr/bin/python2.6

Python 入门

解释器

我们经常在py脚本的第一行 看到如下的代码:

#!/usr/bin/python  或者  #!/usr/bin/env python  那么它的作用是?

  #!/usr/bin/Python 是告诉操作系统执行这个脚本的时候,调用/usr/bin下的python解释器;

  #!/usr/bin/env python这种用法是为了防止操作系统用户没有将python装在默认的/usr/bin路径里。

  当系统看到这一行的时候,首先会到env设置里查找python的安装路径,再调用对应路径下的解释器程序完成操作。推荐这种写法

  如此一来,我们就可以通过: ./hello.py 执行即可。

  ps:执行前需给予 hello.py 执行权限,chmod 755 hello.py

内容编码

  python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)

  显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode

  Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,注:此处说的的是最少2个字节,可能更多

  UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...

  所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:

  报错:ascii码无法表示中文

  1. #!/usr/bin/env python
  2.  
  3. print "你好,世界"

改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3.  
  4. print "你好,世界"

Python2 中字符串的类型:

  Str:Bytes 类型

  Unicode:unicode 类型

  1. # coding:utf8
  2.  
  3. s = '你好'
  4. print len(s) #
  5. print type(s) # <str>
  6. print repr(s) # utf8格式 : '\xe4\xbd\xa0\xe5\xa5\xbd'
  7.  
  8. # Unicode 形式:
  9.  
  10. s = u'你好'
  11. print len(s) #
  12. print type(s) # <unicode>
  13. print repr(s) # u'\u4f60\u597d'
  14.  
  15. # bytes 与 Unicode 混用拼接
  16. print 'hello'+u'world' # 先把 bytes => unicode
  17. print '你好'+u'世界' # 报错, 只能将Ascii码转换,其余字符不行!

Python3 中字符串的类型:

  Str:Unicode 类型

  Bytes:Bytes 类型

  1. # bytes 与 Unicode 混用拼接
  2. print 'hello'+b'world' # 报错,严格区分str和bytes

Python 编码形式:

Python 编码方式有两种:

  1. s = 'hello'
  2. b = b'hello'
  3.  
  4. # 编码 encode Str => Bytes
  5. s.encode('utf8')
  6. bytes(s,encoding='utf8')
  7.  
  8. # 解码 decode Bytes => Str (需要知道原先的编码格式 utf8 or GBK ..)
  9. b.decode('utf8')
  10. str(s,encoding='utf8')

cmd 下的字符显示问题:

  1. print('你好')
  2.  
  3. # py2下为bytes 类型,根据cmd的编码形式去显示 修改为:print(u'你好')
  4. # py3下为unicode 类型,正常显示,符合ISO统一标准的,

查看.py文件的编码格式:

  1. import sys
  2. print sys.getdefaultencoding()
  3.  
  4. # py2: ascii
  5. # py3: utf8

print问题:

在py2里

  1. # coding:utf8
  2. print('你好') # 你好
  3. print(['你好','hello']) # ['\xe4\xbd\xa0\xe5\xa5\xbd', 'hello']

在py3里

  1. # coding:utf8
  2. print('你好') # 你好
  3. print(['你好','hello']) # ['你好', 'hello']

Python 中,print语句都会执行了:str()

  1. # python2
    sys.stdout.write(str(A) + '\n')

栗子:py3,将中文字符转换成二进制( bytes类型进行 for循环 print,会输出10进制数 ! )

  1. name = "李路"
  2.  
  3. len(name)
  4. #长度等于2
  5.  
  6. for i in name:
  7. print(i)
  8. bytes_list = bytes(i , encoding='utf-8')
  9. print(bytes_list )
  10. for b in bytes_list:
  11. print(b,bin(b))
  12.  
  13. #李
  14. #b'\xe6\x9d\x8e'
  15. #230 0b11100110
  16. #157 0b10011101
  17. #142 0b10001110
  18. #路
  19. #b'\xe8\xb7\xaf'
  20. #232 0b11101000
  21. #183 0b10110111
  22. #175 0b10101111

Str 与 Bytes

  1. x = str()
  2. # 功能:
  3. # 1.创建字符串
  4. # 2.转换成字符串 编码类型
  5.  
  6. x = bytes()
  7. # 功能:
  8. # 1.创建字节
  9. # 2.转换成字节 编码类型
  1. def __init__(self, value='', encoding=None, errors='strict'): # known special case of str.__init__
  2. """
  3. str(object='') -> str
  4. str(bytes_or_buffer[, encoding[, errors]]) -> str
  5.  
  6. Create a new string object from the given object. If encoding or
  7. errors is specified, then the object must expose a data buffer
  8. that will be decoded using the given encoding and error handler.
  9. Otherwise, returns the result of object.__str__() (if defined)
  10. or repr(object).
  11. encoding defaults to sys.getdefaultencoding().
  12. errors defaults to 'strict'.
  13. # (copied from class doc)
  14. """
  15. pass

str

  1. def __init__(self, value=b'', encoding=None, errors='strict'): # known special case of bytes.__init__
  2. """
  3. bytes(iterable_of_ints) -> bytes
  4. bytes(string, encoding[, errors]) -> bytes
  5. bytes(bytes_or_buffer) -> immutable copy of bytes_or_buffer
  6. bytes(int) -> bytes object of size given by the parameter initialized with null bytes
  7. bytes() -> empty bytes object
  8.  
  9. Construct an immutable array of bytes from:
  10. - an iterable yielding integers in range(256)
  11. - a text string encoded using the specified encoding
  12. - any object implementing the buffer API.
  13. - an integer
  14. # (copied from class doc)
  15. """
  16. pass

bytes

三、注释

  单行注释:# 被注释内容

  多行注释:""" 被注释内容 """

四、执行脚本传入参数

Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3.  
  4. import sys
  5. print sys.argv

比如用python test.py arg1 arg2运行test.py代码,那么argv列表的内容是[' test.py','arg1','arg2']

五、 pyc 文件

执行Python代码时,如果导入了其他的 .py 文件,那么,执行过程中会自动生成一个与其同名的 .pyc 文件,该文件就是Python解释器编译之后产生的字节码。

ps:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。执行时优先搜索字节码文件

六、变量

变量定义的规则:

  • 变量名只能是 字母、数字或下划线的任意组合
  • 变量名的第一个字符不能是数字
  • 以下关键字不能声明为变量名
  • ['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']

七、输入

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3.  
  4. # 将用户输入的内容赋值给 name 变量
  5. name = raw_input("请输入用户名:")
  6.  
  7. #python3
  8. name = input("请输入用户名:")
  9.  
  10. # 打印输入的内容
  11. print(name)

输入密码时,如果想要不可见,需要利用getpass 模块中的 getpass方法,即:

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3.  
  4. import getpass
  5.  
  6. # 将用户输入的内容赋值给 name 变量
  7. pwd = getpass.getpass("请输入密码:")
  8.  
  9. # 打印输入的内容
  10. print pwd

八、流程控制和缩进

需求一、用户登陆验证

  1. #!/usr/bin/env python
  2. # -*- coding: encoding -*-
  3.  
  4. # 提示输入用户名和密码
  5.  
  6. # 验证用户名和密码
  7. # 如果错误,则输出用户名或密码错误
  8. # 如果成功,则输出 欢迎,XXX!
  9.  
  10. import getpass
  11.  
  12. name = raw_input('请输入用户名:')
  13. pwd = getpass.getpass('请输入密码:')
  14.  
  15. if name == "alex" and pwd == "cmd":
  16. print "欢迎,alex!"
  17. else:
  18. print "用户名和密码错误"

需求二、根据用户输入内容输出其权限

  1. # 根据用户输入内容打印其权限
  2.  
  3. # alex --> 超级管理员
  4. # eric --> 普通管理员
  5. # tony,rain --> 业务主管
  6. # 其他 --> 普通用户
  7.  
  8. name = raw_input('请输入用户名:')
  9.  
  10. if name == "alex"
  11. print "超级管理员"
  12. elif name == "eric":
  13. print "普通管理员"
  14. elif name == "tony" or name == "rain":
  15. print "业务主管"
  16. else:
  17. print "普通用户"

九、while循环

1、基本循环

  1. while 条件:
  2.  
  3. # 循环体
  4.  
  5. # 如果条件为真,那么循环体则执行
  6. # 如果条件为假,那么循环体不执行

2、break

break用于退出所有循环

  1. while True:
  2. print "123"
  3. break
  4. print "456"

3、continue

continue用于退出当前循环,继续下一次循环

  1. while True:
  2. print "123"
  3. continue
  4. print "456"

十、练习题

1、使用while循环输入 1 2 3 4 5 6     8 9 10

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3. num = 0
  4. while num <10:
  5. num += 1
  6. if num == 7:
  7. continue
  8. print(num)

2、求1-100的所有数的和

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3. num = 1
  4. sum = 0
  5. while num<=100:
  6. sum = sum + num
  7. num +=1
  8.  
  9. print(sum)

3、输出 1-100 内的所有奇数

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. num = 1
  5.  
  6. while 1:
  7. if num % 2 == 1:
  8. print(num)
  9. num += 1
  10. if num == 100:
  11. break

4、输出 1-100 内的所有偶数

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3.  
  4. num = 1
  5.  
  6. while 1:
  7. if num % 2 ==0:
  8. print(num)
  9. if num == 100:
  10. break
  11. num += 1

5、求1-2+3-4+5 ... 99的所有数的和

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3.  
  4. num = 1
  5. sum =0
  6.  
  7. while 1:
  8. if num == 100:
  9. break
  10. if num % 2 == 1:
  11. sum = sum + num
  12. else:
  13. sum = sum - num
  14. num +=1
  15.  
  16. print(sum)

6、用户登陆(三次机会重试)

  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3.  
  4. count = 0
  5.  
  6. while 1:
  7. if count == 3:
  8. break
  9. username = input("username :")
  10. password = input("password :")
  11.  
  12. if username == 'admin' and password == 'admin123':
  13. print(" Welcome !")
  14. break
  15. else:
  16. count +=1
  17. continue

【Python之路】第二篇--初识Python的更多相关文章

  1. Python之路(第二篇):Python基本数据类型字符串(一)

    一.基础 1.编码 UTF-8:中文占3个字节 GBK:中文占2个字节 Unicode.UTF-8.GBK三者关系 ascii码是只能表示英文字符,用8个字节表示英文,unicode是统一码,世界通用 ...

  2. Python之路(第一篇):Python简介和基础

    一.开发简介 1.开发:      开发语言:               高级语言:python.JAVA.PHP.C#..ruby.Go-->字节码                低级语言: ...

  3. python之路第二篇(基础篇)

    入门知识: 一.关于作用域: 对于变量的作用域,执行声明并在内存中存在,该变量就可以在下面的代码中使用. if 10 == 10: name = 'allen' print name 以下结论对吗? ...

  4. Python学习【第二篇】Python入门

    Python入门 Hello World程序 在linux下创建一个叫hello.py,并输入 print("Hello World!") 然后执行命令:python hello. ...

  5. python之路1(初识python)

    python简史: python我认为特性就是简洁,灵活,高效. python重要版本: python1991年问世, python2.4:2004,同年django框架诞生. python2.6:2 ...

  6. Python 基础【第二篇】python操作模式

    一.交互模式 #python Python 2.6.6 (r266:84292, Jan 22 2014, 09:42:36) [GCC 4.4.7 20120313 (Red Hat 4.4.7-4 ...

  7. 【Python 开发】第二篇 :Python安装

    一.python3.x安装 1)由于centos7原本就安装了Python2,而且这个Python2不能被删除,因为有很多系统命令,比如yum都要用到. 官网:https://www.python.o ...

  8. Python开发【第二篇】:初识Python

    Python开发[第二篇]:初识Python   Python简介 Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏 ...

  9. AI之路,第二篇:python数学知识2

    第二篇:python数学知识2 线性代数 导入相应的模块: >>> import numpy as np     (数值处理模块)>>> import scipy ...

随机推荐

  1. 用aspx文件作为模板

    用aspx文件作为模板 首先申明:标题中的如果是可以去掉的. 想写这篇文章很长时间了,一来是跟大家分享一下,别浪费时间在写代码生成器上面了,什么CodeSmith,XXCodeGenerator等等, ...

  2. TFS的安装

    TFS的安装 本系列的实例将采用TFS 2012+Sql Server2012编写. TFS的完整版本安装最好是在Windows server2008 64位以上版本中,其包括64位的SQL SERV ...

  3. PHP之-json转数组,支持多层嵌套json

    function json_to_array($str) { if (is_string($str)) $str = json_decode($str); $arr=array(); foreach( ...

  4. 蓝牙UUID——Android各种蓝牙设备的UUID

    本文转自:http://www.14blog.com/archives/481 UUID是“Universally Unique Identifier”的简称,通用唯一识别码的意思.对于蓝牙设备,每个 ...

  5. 汇编条件判断整理(JCC,CMP/TEST的实现)

    比较的实现 我们知道CMP是比较两个寄存器内容的指令,但这是如何实现的? 当执行到CMP指令的时候会读取这两个寄存器的内容,并加以减法运算,结果本身不保留,并按照结果设置符号位(属算术运算). CMP ...

  6. 神经机器翻译(NMT)相关资料整理

    作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 1 简介 自2013年提出了神经机器翻译系统之后,神经机器翻译系统 ...

  7. 最新samba.tar.gz安装方法

    看了韩顺平老师的samba.rpm包安装后,想自己也动手试试,便在samba官网找啊找,只找到一个tar.gz包,于是开始了这一段漫长的跨时两天的安装旅途... 1.首先,看看系统是否已经安装了sam ...

  8. Golang爬虫示例包系列教程(一):pedaily.com投资界爬虫

    Golang爬虫示例包 文件结构 自己用Golang原生包封装了一个爬虫库,源码见go get -u -v github.com/hunterhug/go_tool/spider ---- data ...

  9. Java SE ——TCP协议网络编程(三)

    之前的代码中关闭了 socket 对象的输入流与输出流,但并没有关闭掉socket 对象,会造成服务器资源的浪费,应通过调用 socket 的 close() 方法来关闭当前的socket 对象. 因 ...

  10. OpenH264

    转自:http://blog.csdn.net/chinabinlang/article/details/41209053 目前最常用的264工程师x264: 最近有又有一个开源工程OpenH264, ...