zoukankan      html  css  js  c++  java
  • 初见Python

    初见Python

    版本:Python 3.x

    我现在是一名在职运维工程师,每天做着枯燥的工作,每个月都在重复、重复、重复…把我刚毕业那会的雄心斗志,几乎快消磨殆尽,所以我决定转战开发。想自己的目标去努力、去迈进。

    记得刚毕业那会,对开发甚是喜爱,结果怎么就干了个运维呢?!有点不明所以…干运维两年了…每次看到客户的丑恶嘴脸,都很是蓝瘦、香菇…所以决定,转战开发…

    选择语言:近期云计算以及各种开源项目都搞得风生水起,加上之前对Python有些许了解,所以决定选择Python这门语言。

    • Python的优缺点:

    优点:

    1、  Python看上去总是简单易懂:初学者学Python,不但入门容易,而且容易深入下去,可以编写那些非常复杂的程序。

    2、  开发效率高:Python有非常强大的第三方库,基本上你想通过计算机实现任何功能,Python官方库都有对应的模块进行支持

    3、  高级语言:当你用Python语言编写程序的时候,你无需考虑诸如如何管理你的程序使用的内存一类的底层细节

    4、  可移植性:由于它的开源本质,Python已经被移植在许多平台上(经过改动使它能够工作在不同平台上)。如果你小心地避免使用依赖于系统的特性,那么你的所有Python程序无需修改就几乎可以在市场上所有的系统平台上运行。

    5、  可扩展性:如果你需要你的一段关键代码运行的更快或者希望某些算法不公开,你可以把你的部分程序用C或C++编写,然后在你的Python程序中使用它们。

    6、  可嵌入性:你可以把Python嵌入你的C/C++程序,从而向你的程序用户提供脚本功能。

    缺点:

    1、  速度慢:Python的运行速度相比C语言确实慢很多,跟JAVA相比也要慢一些,因此这也是很多所谓的大牛不屑于使用Python的主要原因,但其实这里所指的运行速度慢在大多数情况下用户是无法直接感知到的,必须借助测试工具才能体现出来。在大多数情况下Python已经完全可以满足你对程序速度的要求,如果需要写对速度要求极高的搜索引擎等,还是C更好一些。

    2、  代码不能加密:因为Python是解释型语言,它的源码都是以文件的形式存放的;这一点不一定是缺点,如果项目要求源码必须是加密的,一开始就不应该用Python来实现。

    3、  线程不能利用多CPU:这是Python被人诟病最多的一个缺点,GIL(Global Interpreter Lock全局解释器锁)是计算机程序设计语言解释器用于同步线程的工具,使得任何时刻仅有一个线程在执行,Python的线程是操作系统的原生线程。在Linux上为pthread,在Windows上为Win thread,完全有操作系统调度线程的执行。一个Python解释器进程内有一条主线程,以及多条用户程序的执行线程。即使在多核CPU平台上,由于GIL的存在,所以禁止多线程的并行执行。

    4、  …………

    • Python解释器

    当我们编写Python代码时,我们得到的是一个包含Python代码的以.py为拓展名的文本文件。要运行代码,就需要Python解释器去执行.py文件。

    1、  CPython

    CPython是使用最广的Python解释器

    当我们从Python官网下载并安装好Python后,我们就直接获得了一个官方版本的解释器CPython。这个解释器是用C语言开发的,所以叫CPython。在命令行下运行python就是启动CPython解释器。

    2、  PyPy

    PyPy是另外一个Python解释器,他的目标是执行速度。PyPy采用JIT技术,对Python代码进行动态编译(注意不是解释),所以可以显著提高Python代码的执行速速。

    使用PyPy执行Python需要注意了解:PyPy和CPython的不同点。

    绝大部分Python代码都可以在PyPy下执行,但是PyPy和CPython有一些是不同的,这就导致形同的Python代码在两种解释器下执行可能会有不同的结果。

    • 向世界问好---Hello World程序

    Linux下touch一个文件叫helloworld.py并输入print(“Hello World!”)

    然后执行 python helloworld.py输出 Hello World!

    [root@localhost ~]#

    [root@localhost ~]# touch helloworld.py

    [root@localhost ~]# vim helloworld.py

    [root@localhost ~]# python helloworld.py

    Hello World!

    [root@localhost ~]#

    上一个操作中执行python helloworld.py时,明确的指出helloworld.py脚本由Python解释器来执行。如果想要类似于执行shell脚本一样执行Pyhton脚本,例如:./helloworld.py那么就需要在helloworld.py文件的头部指定解释器,如下:

    #!/usr/bin/env python

    print("Hello World!")

    但这样,需要在执行前给helloworld.py执行权限,chmod 755 helloworld.py

    • 变量

    1、声明变量

    #_*_coding:utf-8_*_

    name = "White Vans"

    上述代码声明了一个变量,变量名:name  变量name的值:" White Vans"

    变量定义的规则:

        变量名只能是字母、数字、下划线的任意组合

        变量名的第一个字符不能是数字

        以下关键字不能声明为变量名

    ['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']

    2、变量的赋值

    name = " White Vans "

    name2 = name

    print(name,name2)

    name = "hippie"

    print("What is the value of name2 now?")

    • 字符编码

    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码无法表示中文

    #!/usr/bin/env python

    print "你好,世界!"

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

    #!/usr/bin/env python

    # -*- coding: utf-8 -*-

    print "你好,世界!"

    • 注释

      当行注释:# 被注释内容

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

    eg:

    #for i in range(0,10,1):
    # print("loop",i)
    #
    #for i in range(0,10,2):
    # #最后一个数(2)是步长
    # print("loop",i)
    '''
    for i in range(0,10):
    if i < 3:
    print("loop",i)
    else:
    continue
    print("hehe...")
    '''
    • 用户输入

    #!/usr/bin/env python

    #_*_coding:utf-8_*_

    name=input(“Please input your name:”)

    print(“Hello”+name)

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

    #!/usr/bin/env python

    #_*_coding:utf-8_*_

    import getpass

    # 将用户输入的内容赋值给 password 变量

    password = getpass.getpass("Please input password:")

    # 打印输入的内容

    print(password)

  • 相关阅读:
    MySQL · 引擎特性 · InnoDB 事务锁简介
    锁大全与 GDB调试
    docker(4):coreos+docker+rancher真厉害
    TIDB ---NEW SQL
    Linux的内存回收和交换
    TLS握手优化详解
    北风网JAVA 大数据培训
    MySQL 5.7 深度解析: JSON数据类型使用
    MySQL 5.7 深度解析: 临时表空间
    在Linux最大打开文件数限制下 MySQL 对参数的调整
  • 原文地址:https://www.cnblogs.com/hprhm8/p/7357523.html
Copyright © 2011-2022 走看看