zoukankan      html  css  js  c++  java
  • Python基础第一天

    1、python创世人:吉多.范罗苏姆
    2、TIOBE排行榜
        python的发展趋势,应用领域,使用的公司
        由上图可见,Python整体呈现上升趋势,反映出Python应用越来越广泛并且也得到了行业内的认可。
        
        Python的应用领域众多,如数据分析、组件集成、网络服务、图像处理、数值和科学计算等众多领域。
     
        目前业内几乎所有大中型互联网企业都在使用Python,如:Youtub、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo、Fackbook、NASA、百度、腾讯、汽车之家、美团等
     
    3、python的发展历程:

      1989年,为了打发圣诞节假期,Guido开始写Python语言的编译器。Python这个名字,来自Guido所挚爱的电视剧Monty Python’s Flying Circus。他希望这个新的叫做Python的语言,能符合他的理想:创造一种C和shell之间,功能全面,易学易用,可拓展的语言
      1991年,第一个Python编译器诞生。它是用C语言实现的,并能够调用C语言的库文件。从一出生,Python已经具有了:类,函数,异常处理,包含表和词典在内的核心数据类型,以及模块为基础的拓展系统
      Granddaddy of Python web frameworks, Zope 1 was released in 1999
      Python 1.0 - January 1994 增加了 lambda, map, filter and reduce.
      Python 2.0 - October 16, 2000,加入了内存回收机制,构成了现在Python语言框架的基础
      Python 2.4 - November 30, 2004, 同年目前最流行的WEB框架Django 诞生
      Python 2.5 - September 19, 2006
      Python 2.6 - October 1, 2008
      Python 2.7 - July 3, 2010
      In November 2014, it was announced that Python 2.7 would be supported until 2020, and reaffirmed that there would be no 2.8 release as users were expected to move to   (2014年11月,宣布Python 2.7将支持到2020年,并重申将不会有2.8版本,用户尽快迁移到Python 3.4+)

      Python 3.4+ as soon as possible
      Python 3.0 - December 3, 2008
      Python 3.1 - June 27, 2009
      Python 3.2 - February 20, 2011
      Python 3.3 - September 29, 2012
      Python 3.4 - March 16, 2014
      Python 3.5 - September 13, 2015
      Python 3.6 - December 16,2016

     
    4、python是一门解释型语言
    5、解释型、编译型、混合型语言常用的有那些:
        编译型:
            C、C++、GO、Swift、Object-C、Pascal    
        解释型:
            JavaScript、Python、Ruby、PHP、Perl、Erlang
        混合型:
            JAVA、C#
     
    6、解释型、编译型之间的优缺点
        编译型:执行效率高、移植性查
            优点:
            1、编译器会对代码进行优化
            2、编译只做一次,运行时不需要再编译
            2、可以脱离语言环境独立运行
            缺点:
            1、编译后的代码,如果需要修改,就需要对整个模块进行重新编译
            2、编译时会根据对应的运行环境生产机器码,不同的操作系统之间移植就会存在问题,需要根据运行的操作系统环境编译不同的可执行文件
            
        解释型:良好的兼容性、灵活
            优点:
            1、良好的平台兼容性,在任何环境中都可以运行,前提是在安装了解释器(虚拟机)
            2、灵活,可以直接进行代码修改,不用停机维护
            3、部署速度快
            缺点:
            1、每次运行的时候都需要解释一遍,性能上不如编译型语言
            
    7、动态类型言语、静态类型语言
        1、动态类型语言
            动态类型语言是指运行期间才去做数据类型检查的语言,也就是说,在用动态类型的语言编译时,不需要给任何便利指定数据类型,该语言会在第一次赋值给变量时,在内部将数据类型记录下来
            Python和Ruby是一种典型的动态类型语言,其他的各种脚本语言如VBSCript多少也属于动态类型语言    
        2、静态类型语言
            静态类型语言与动态类型语言相反,它的数据类型是在编译期间检查的,也就是说,在写程序时要声明所有变量的数据类型,C/C++是静态类型语言的典型代表,其他的静态类型语言还有C#、JAVA等
     
    8、强类型定义语言、弱类型定义语言
        1、强类型定义语言
            强制数据类型定义的语言,变量被指定了某个数据类型,如果不经过强制转换,那么它就永远是这个数据类型
        2、弱类型定义语言
            弱类型定义语言的数据类型可以被忽略,它与强类型定义语言相反,一个变量可以赋不同数据类型的值    
        强类型定义语言在速度上可能稍微逊色于弱类型定义语言,但是强类型定义语言带来的严谨性能够有效的避免许多错误
     
        Python是动态语言,强类型定义语言:解释性的强类型语语言
        VBScript是动态语言,弱类型定义语言
        JAVA是静态语言,强类型定义语言
       
    9、Python的优缺点
        优点:
        1、Python的定位是"优雅"、"明确"、"简单",所有Python程序看上去总是简单易懂,Python,入门容易,深入下去也可以编写那些非常复杂的程序
        2、开发效率高,Python有非常强大的第三方库,大大降低开发周期,避免重复造轮子
        3、高级语言————当你编写Python程序时,无需考虑诸如如何管理你的程序使用的内存一类的底层细节
        4、可移植性————由于它开源的本质,Python已经被移植在许多平台上。如果小心避免使用依赖于系统的特性,那么你的所有Python程序无需修改就几乎可以在市场上的所有平台上运行
        5、可扩展性————如果你需要你的一段关键代码运行得更快或者希望某些算法不公开,你可以把你的部分程序用C或C++编写,然后在你的Python程序中使用它们
        6、可嵌入性———— 可以把Python嵌入C/C++程序,从而向程序用户提供脚本功能
        缺点:
        1、运行速度慢:Python的运行速度相比C语言确实慢很多,比JAVA也要慢一些,因此很多所谓的大牛不屑使用Python的主要原因,但其实这里所指的运行速度慢大多数情况下用户是无法直接感知到的,必须借组于测试工具才能体现出来,比如你用C运行一个程序花了0.01s,用Pyhon是0.1s,这也C语言直接比Python快了10倍,算是非常夸张的了,但是你是无法直接通过肉眼感知的,因为一个正常人所能感知的时间最小单位是0.15-0.4s左右。其实在大多数情况下Python已经完全可以满足你对程序速度的要求,除非你要写对速度要求极高的搜索引擎等待,在这种情况下,当然还是建议你使用C语言实现
        2、代码不能加密:因为Python是解释性语言,它的源码都是以名文形式存放的,不过我不认为这算是一个缺点,如果你的项目要求源码必须是加密的,那你一开始就不应该用Python去实现
        3、线程不能利用多CPU问题:这是Python被人诟病最多的一个缺点,GIL即全局解释器锁(Global Interpreter Lock),是计算机程序设计语言解释器用于同步线程的工具,使得任何时刻仅有一个线程在执行,Python的线程是在操作系统的原生线程。在Linux上为pthread,在Windows上为Win thread,完全由操作系统调度线程的执行。一个Python解释器进程内有一条主线程,以及多条用户程序的执行线程。即使在多核CPU平台上,由于GIL的存在,所以禁止多线程的并行执行。关于这个问题的折中解决方法,我们在以后线程和进程章节里再进行详细探讨
     
    当我们编写Python代码时,我们得到的是一个包含Python代码的以.py为扩展名的文本文件。要运行代码,就需要Python解释器去执行.py文件
     
    由于整个Python语言从规范到解释器都是开源的,所以理论上只有水平够高,任何人都可以编写Python解释器
     
    10、Python的种类
        CPython:这个解释器是C语言开发的,所以叫CPython,CPython是使用最广的Python的解释器
        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的字节码
        小结:Python的解释器很多,但使用最广泛的还是CPython。如果要和JAVA或.Net平台交互,最好的办法不是用Jython或IronPython,而是通过网络调用来交互,确保各个程序之间的独立性
     
    11、Python基础初始
        1、运行Python代码
            在H盘下创建一个 firstPython.py文件内容是:print('Hello World!')
            打开windows命令行输入cmd,确定后,写入代码python H:firstPython.py
             您已经运行了第一个python程序, 即:终端---->cmd-----> python  文件路径(python H:firstPython.py)。 回车搞定~
            
      
        2、解释器
            上一步中执行python H:firstPython.py 时,明确的指出firstPython.py脚本由python解释器来执行
            如果想要类似于执行shell脚本一样执行python脚本,列:./firstPython.py,那么就需要在firstPython.py文件的头部指定解释器,代码如下:
        #!/usr/bin/env python
        print('Hello World!')
            如此一来,执行:Linux:./firstPython.py 即可
            PS:执行前需要给予 firstPython.py执行权限,chmod 755 ./firstPython.py
     
    12、内容编码
        1、Python2解释器在加载.py 文件中代码时,会对内容进行编码(默认 ascill ),而Python3对内容进行编码的默认:utf-8
        2、ASCII(American Standard Code for Information Inerchange,美国标准信息交换代码) 是基于拉丁字母的一套电脑编码系统,主要于显示现代英语和其他西欧语言,最多用8位来表示一个字节,即:2**8 = 256,所以,ASCII码最多只能表示256个符号。
    Bin(二进制)
    Oct(八进制)
    Dec(十进制)
    Hex(十六进制)
    缩写/字符
    解释
    0000 0000
    0
    0
    00
    NUL(null)
    空字符
    0000 0001
    1
    1
    01
    SOH(start of headline)
    标题开始
    0000 0010
    2
    2
    02
    STX (start of text)
    正文开始
    0000 0011
    3
    3
    03
    ETX (end of text)
    正文结束
    0000 0100
    4
    4
    04
    EOT (end of transmission)
    传输结束
    0000 0101
    5
    5
    05
    ENQ (enquiry)
    请求
    0000 0110
    6
    6
    06
    ACK (acknowledge)
    收到通知
    0000 0111
    7
    7
    07
    BEL (bell)
    响铃
    0000 1000
    10
    8
    08
    BS (backspace)
    退格
    0000 1001
    11
    9
    09
    HT (horizontal tab)
    水平制表符
    0000 1010
    12
    10
    0A
    LF (NL line feed, new line)
    换行键
    0000 1011
    13
    11
    0B
    VT (vertical tab)
    垂直制表符
    0000 1100
    14
    12
    0C
    FF (NP form feed, new page)
    换页键
    0000 1101
    15
    13
    0D
    CR (carriage return)
    回车键
    0000 1110
    16
    14
    0E
    SO (shift out)
    不用切换
    0000 1111
    17
    15
    0F
    SI (shift in)
    启用切换
    0001 0000
    20
    16
    10
    DLE (data link escape)
    数据链路转义
    0001 0001
    21
    17
    11
    DC1 (device control 1)
    设备控制1
    0001 0010
    22
    18
    12
    DC2 (device control 2)
    设备控制2
    0001 0011
    23
    19
    13
    DC3 (device control 3)
    设备控制3
    0001 0100
    24
    20
    14
    DC4 (device control 4)
    设备控制4
    0001 0101
    25
    21
    15
    NAK (negative acknowledge)
    拒绝接收
    0001 0110
    26
    22
    16
    SYN (synchronous idle)
    同步空闲
    0001 0111
    27
    23
    17
    ETB (end of trans. block)
    结束传输块
    0001 1000
    30
    24
    18
    CAN (cancel)
    取消
    0001 1001
    31
    25
    19
    EM (end of medium)
    媒介结束
    0001 1010
    32
    26
    1A
    SUB (substitute)
    代替
    0001 1011
    33
    27
    1B
    ESC (escape)
    换码(溢出)
    0001 1100
    34
    28
    1C
    FS (file separator)
    文件分隔符
    0001 1101
    35
    29
    1D
    GS (group separator)
    分组符
    0001 1110
    36
    30
    1E
    RS (record separator)
    记录分隔符
    0001 1111
    37
    31
    1F
    US (unit separator)
    单元分隔符
    0010 0000
    40
    32
    20
    (space)
    空格
    0010 0001
    41
    33
    21
    !
    叹号
    0010 0010
    42
    34
    22
    "
    双引号
    0010 0011
    43
    35
    23
    #
    井号
    0010 0100
    44
    36
    24
    $
    美元符
    0010 0101
    45
    37
    25
    %
    百分号
    0010 0110
    46
    38
    26
    &
    和号
    0010 0111
    47
    39
    27
    '
    闭单引号
    0010 1000
    50
    40
    28
    (
    开括号
    0010 1001
    51
    41
    29
    )
    闭括号
    0010 1010
    52
    42
    2A
    *
    星号
    0010 1011
    53
    43
    2B
    +
    加号
    0010 1100
    54
    44
    2C
    ,
    逗号
    0010 1101
    55
    45
    2D
    -
    减号/破折号
    0010 1110
    56
    46
    2E
    .
    句号
    00101111
    57
    47
    2F
    /
    斜杠
    00110000
    60
    48
    30
    0
    数字0
    00110001
    61
    49
    31
    1
    数字1
    00110010
    62
    50
    32
    2
    数字2
    00110011
    63
    51
    33
    3
    数字3
    00110100
    64
    52
    34
    4
    数字4
    00110101
    65
    53
    35
    5
    数字5
    00110110
    66
    54
    36
    6
    数字6
    00110111
    67
    55
    37
    7
    数字7
    00111000
    70
    56
    38
    8
    数字8
    00111001
    71
    57
    39
    9
    数字9
    00111010
    72
    58
    3A
    :
    冒号
    00111011
    73
    59
    3B
    ;
    分号
    00111100
    74
    60
    3C
    <
    小于
    00111101
    75
    61
    3D
    =
    等号
    00111110
    76
    62
    3E
    >
    大于
    00111111
    77
    63
    3F
    ?
    问号
    01000000
    100
    64
    40
    @
    电子邮件符号
    01000001
    101
    65
    41
    A
    大写字母A 
    01000010
    102
    66
    42
    B
    大写字母B
    01000011
    103
    67
    43
    C
    大写字母C
    01000100
    104
    68
    44
    D
    大写字母D
    01000101
    105
    69
    45
    E
    大写字母E
    01000110
    106
    70
    46
    F
    大写字母F
    01000111
    107
    71
    47
    G
    大写字母G
    01001000
    110
    72
    48
    H
    大写字母H
    01001001
    111
    73
    49
    I
    大写字母I
    01001010
    112
    74
    4A
    J
    大写字母J
    01001011
    113
    75
    4B
    K
    大写字母K
    01001100
    114
    76
    4C
    L
    大写字母L
    01001101
    115
    77
    4D
    M
    大写字母M
    01001110
    116
    78
    4E
    N
    大写字母N
    01001111
    117
    79
    4F
    O
    大写字母O
    01010000
    120
    80
    50
    P
    大写字母P
    01010001
    121
    81
    51
    Q
    大写字母Q
    01010010
    122
    82
    52
    R
    大写字母R
    01010011
    123
    83
    53
    S
    大写字母S
    01010100
    124
    84
    54
    T
    大写字母T
    01010101
    125
    85
    55
    U
    大写字母U
    01010110
    126
    86
    56
    V
    大写字母V
    01010111
    127
    87
    57
    W
    大写字母W
    01011000
    130
    88
    58
    X
    大写字母X
    01011001
    131
    89
    59
    Y
    大写字母Y
    01011010
    132
    90
    5A
    Z
    大写字母Z
    01011011
    133
    91
    5B
    [
    开方括号
    01011100
    134
    92
    5C
    反斜杠
    01011101
    135
    93
    5D
    ]
    闭方括号
    01011110
    136
    94
    5E
    ^
    脱字符
    01011111
    137
    95
    5F
    _
    下划线
    01100000
    140
    96
    60
    `
    开单引号
    01100001
    141
    97
    61
    a
    小写字母a 
    01100010
    142
    98
    62
    b
    小写字母b
    01100011
    143
    99
    63
    c
    小写字母c
    01100100
    144
    100
    64
    d
    小写字母d
    01100101
    145
    101
    65
    e
    小写字母e
    01100110
    146
    102
    66
    f
    小写字母f
    01100111
    147
    103
    67
    g
    小写字母g
    01101000
    150
    104
    68
    h
    小写字母h
    01101001
    151
    105
    69
    i
    小写字母i
    01101010
    152
    106
    6A
    j
    小写字母j
    01101011
    153
    107
    6B
    k
    小写字母k
    01101100
    154
    108
    6C
    l
    小写字母l
    01101101
    155
    109
    6D
    m
    小写字母m
    01101110
    156
    110
    6E
    n
    小写字母n
    01101111
    157
    111
    6F
    o
    小写字母o
    01110000
    160
    112
    70
    p
    小写字母p
    01110001
    161
    113
    71
    q
    小写字母q
    01110010
    162
    114
    72
    r
    小写字母r
    01110011
    163
    115
    73
    s
    小写字母s
    01110100
    164
    116
    74
    t
    小写字母t
    01110101
    165
    117
    75
    u
    小写字母u
    01110110
    166
    118
    76
    v
    小写字母v
    01110111
    167
    119
    77
    w
    小写字母w
    01111000
    170
    120
    78
    x
    小写字母x
    01111001
    171
    121
    79
    y
    小写字母y
    01111010
    172
    122
    7A
    z
    小写字母z
    01111011
    173
    123
    7B
    {
    开花括号
    01111100
    174
    124
    7C
    |
    垂线
    01111101
    175
    125
    7D
    }
    闭花括号
    01111110
    176
    126
    7E
    ~
    波浪号
    01111111
    177
    127
    7F
    DEL (delete)
    删除
     
      显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode
      Unicode:(统一码,万国码,单一码)是一种在计算机上使用的字符编码。Unicode是为了解决传统的字符编码方案的局限而产生的,它为每种语言的每个字符设定了统一并且唯一的二进制编码,规定定虽有的字符和符号最少由16为来表示(2个字节),即:2 **16 = 65536
     
      注:此处说的的是最少2个字节,可能更多
     
      UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...
      python2解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:
            #!/usr/bin/env python
            print('你好 世界!')
      报错:ascii码无法表示中文
      改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:      
            #!/usr/bin/env python
            # -*- encoding: utf-8 -*-
            print('你好 世界!')
      python3解释器默认编码utf-8,中文不会报错:
            #!/usr/bin/env python
            print('你好 世界!')
       
    13、注释
        单行注释:# 被注释的内容
        多行注释:"""被注释内容""",'''被注释内容'''     
     
    14、变量
        变量:把程序运行的中间结果临时的存在内存里,以便后续的代码调用
        声明变量:name =  "tail"
        变量的作用:呢称,其代指向内存里某个地址中保存的内容
        变量定义的规则:
        变量名只能是 字母、数字、下划线的任意组合,变量名不能以数字开头
        
        以下关键字不能声明为变量:
        ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lamdba', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yeild']    
     
        变量的定义要具有可描述性
     
        推荐定义方式
        #驼峰体:AgeOfOldboy = 56
        #下划线:age_of_oldboy = 56
     
        变量的赋值:test1 = 56 test2 = 56 test3 = 57
        定义变量不好的方式:
            变量名为中文、拼音,变量名过长,变量名词不达意
     
    15、常量
        常量:指不变的量,如pai 3.1415926...,或在程序运行过程中不会改变的量
        常量命名规则:AGE_OF_OLDBOY = 56
        
         在c语言中有专门的常量定义语法,const int count = 60;一旦定义为常量,更改即会报错
       
    16、程序交互
        代码1:输入用户名,打印输入的用户名    
        #将用户输入的内容赋值给 name 变量
        name = input("请输入用户名:")
        
        #打印输入的内容
        print(name)
        代码2:输入多个不同的用户信息,打印输入的用户信息    
      name = input("请输入用户名:")
      age = input("请输入你的年龄:")
      hometown = input("请输入你的家乡地址:")
     
      print("Hello ",name, "your are ", age, "years old, you came from ",hometown) 
      请输入用户名:小红
      请输入你的年龄:18
      请输入你的家乡地址:中国
      Hello  小红 your are  18 years old, you came from  中国
     
    17、基础数据类型
        数据类型:先说3种、数字、字符串、布尔类型
       
        整数类型:int
        在32位机器上,整数的位数,取值范围为-2**31~2**31-1,即-2147483648~2147483648
        在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
        
        长整型:long
        根C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大
     
        注意:自Python2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了
     
        注意:Python3里不再有long类型,全部是int类型
        Python2:
        >>> a= 2**64
        >>> type(a) #type()是查看数据类型的方法
        <type 'long'>
        >>> b = 2**30
        >>> type(b)
        <type 'int'>
     Python3:    
        >>> a= 2**64
        >>> type(a) #type()是查看数据类型的方法
        <type 'int'
        
     字符串类型(str)
     在Python中,加入引号的字符都被认为是字符串
        >>> name = "NZD"  #双引号
        >>> age = "24"    #只要加引号就是字符串
        >>> age2 = 24   #int
        >>>
        >>> msg = '''My name is NZD, I am 24 years old!''' #3个引号也可以
        >>>
        >>> hometown = 'ShanDong' #单引号也可以
        那单引号、双引号、多引号有什么区别呢?单引号、双引号没有什么区别,下面的情况,你需要考虑单双引号的配合使用:msg = "My name is NZD, I'm 24 years old!"
        多引号的作用:原样输出
        msg = '''
        今天我想写首小诗,
        歌颂我的同桌,
        你看他那乌黑的短发,
        好像一只炸毛鸡。
        '''
        print(msg)
        输出:

      今天我想写首小诗, 歌颂我的同桌, 你看他那乌黑的短发, 好像一只炸毛鸡。
        
        字符串拼接:数字可以进行加减乘除等运算,字符串呢?也能,但是只能进行 "相加" 和 "相减" 运算
        >>> name = 'NZD'
        >>> age = ' 24'
        >>>
        >>> name + age #相加其实就是简单拼接'NZD 24'
        NZD 24
        >>>
        >>> name * 10 
       'NZDNZDNZDNZDNZDNZDNZDNZDNZDNZD'
        注意:字符串的拼接只能是双方都是字符串,不能跟数字或其他类型拼接
            
        >>> name = 'NZD'
        >>> age = 24
        >>> name + age
        Traceback (most recent call last):
        File "<stdin>", line 1, in <module>
        TypeError: cannot concatenate 'str' and 'int' objects #错误提示数字 和 字符 不能拼接
        
        布尔值(True、False)
        布尔类型:一个True(真),一个False(假)
        >>> a=3
        >>> b=5
        >>> a > b #不成立就是False,即假False
        False
        >>> a < b #成立就是True, 即真
        True
        
    18、格式化输出
            %s就是代表字符串占位符,%d,数字占位符(只能输入数字)
           现有一练习需求,问用户的姓名、年龄、工作、爱好 ,然后打印成以下格式
         ------------ info of NZD -----------
         Name : NZD
         Age : 24
         job : Teacher
         Hobbie: girl
         ------------- end -----------------
          
      代码:
    name = input("Name:")
    age = input("Age:")
    job = input("Job:")
    hobbie = input("Hobbie:")
    
    #info里的每个%s就是一个占位符,本行的代表 后面拓号里的 name
    info = '''
    ------------ info of %s ----------- 
    Name : %s #代表 name
    Age : %s #代表 age
    job : %s #代表 job
    Hobbie: %s #代表 hobbie
    ------------- end -----------------
    ''' %(name,name,age,job,hobbie) # 这行的 % 号就是 把前面的字符串 与拓号 后面的 变量 关联起来
    
    print(info)
    Name:小红
    Age:18
    Job:Teacher
    Hobbie:running
    
    ------------ info of 小红 ----------- 
    Name : 小红 #代表 name
    Age : 18 #代表 age
    job : Teacher #代表 job
    Hobbie: r #代表 hobbie
    ------------- end -----------------
        注意:input接收的所有输入默认都是字符串格式!
                数字类型: age = int( input("Age:") )
            
    19、基本运算符
        运算符:算数运算符、比较运算符、逻辑运算符、赋值运算符、成员运算符、身份运算符、位运算符
        算术运算符:+、-、*、/...
     假设变量:a=10,b=20
     
     
        比较运算符 : >、<、 ==...
     假设变量:a=10,b=20
     
     
      赋值运算符: 
     假设变量:a=10,b=20
     
       
     逻辑运算符:not 、and 、 or
     假设变量:a=10,b=20
     

     针对逻辑运算的进一步研究:在没有()的情况下not 优先级高于 and,and优先级高于or,即优先级关系为( )>not>and>or,同一优先级从左往右计算

     例1:
    print(3>4 or 4<3 and 1==1) # 3>4 or 假 = 假
    
    print(1 < 2 and 3 < 4 or 1>2 ) # 真 or 1>2 = 真
    
    print(2 > 1 and 3 < 4 or 4 > 5 and 2 < 1) # 真 or 假 = 真
    
    print(1 > 2 and 3 < 4 or 4 > 5 and 2 > 1 or 9 < 8) # 假 or 假 or 9 < 8 >> 假 or 9 < 8 = 假
    
    print(1 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6) # 假 or 假 and 9 > 8 or 7 < 6 >>  假 or 假 or 7 < 6 = 假
    
    print(not 2 > 1 and 3 < 4 or 4 > 5 and 2 > 1 and 9 > 8 or 7 < 6) # 假 and 3 < 4 or  假 or 7 < 6 >>  假 or 假 or 7 < 6 = 假

     输出:

    False
    True
    True
    False
    False
    False

     例2:

    print(8 or 4)   #真 8
    print(0 and 3)  #假 0
    print(4 and 3)  #真 3
    print(0 and 3)  #假 0
    print(0 or 3)   #真 3
    print(0 or 4 and 3 or 7 or 9 and 6) # 0 or 3 or 7 or 9 and 6 >> 0 or 3 or 7 or 6 >>  3 or 7 or 6 >> 3

     输出:

    8
    0
    3
    0
    3
    3
       逻辑运算符:逻辑判断结束时,遇到数字输出数字,遇到比较运算符输出比较结果True 或 False
    1)、6 or 2 > 1     6
    2)、3 or 2 > 1     3
    3)、0 or 5 < 4     False
    4)、5 < 4 or 3     3
    5)、2 > 1 or 6     True
    6)、3 and 2 > 1    True
    7)、0 and 3 > 1    0
    8)、2 > 1 and 3    3
    9)、3 > 1 and 0    0
    10)、3 > 1 and 2 or 2 < 3 and 3 and 4 or 3 > 2  2
     成员运算符:in、not in
        判断子元素是否在原字符串(字典,列表,集合)中:
      >>> 'in' in ['and','in','not in']
      True
      >>> 'x' in 'zxcvbnm'
      True
      >>> 'x' not in 'zxcvbnm'
      False
     
    20、流程控制——if
        假如把写程序比做走路,那我们到现在为止,一直走的都是直路,还没遇到过分叉口,想象现实中,你遇到了分叉口,然后你决定往哪拐必然是有所动机的。你要判断那条岔路是你真正要走的路,如果我们想让程序也能处理这样的判断怎么办? 很简单,只需要在程序里预设一些条件判断语句,满足哪个条件,就走哪条岔路。这个过程就叫流程控制
        if...else...
        if...elif...
        
        单分支:
            if 条件:
            满足条件后要执行的代码
     
        双分支:
        """
        if 条件:
        满足条件执行代码
        else:
        if条件不满足就走这段
        """
        AgeOfOldboy = 48
        if AgeOfOldboy > 50 :
            print("Too old, time to retire..")
        else:
            print("还能折腾几年!")
     缩进:每个条件的下一行都缩进4个空格,这是为什么呢?这就是Python的一大特色,强制缩进,目的是为了让程序知道,每段代码依赖哪个条件,如果不通过缩进来区分,程序怎么会知道,当你条件成立后,去执行哪些代码呢?
        其他的语言里,大多数通过{}来确定代码块,比如CC++、JAVA、JavaScript都是这也的,看一个JavaScript代码的例子:
        var age = 56
        if ( age < 50){
            console.log("还能折腾")
            console.log('可以执行多行代码')
        }else{
            console.log('太老了')
        }
        在有{}来区分代码块的情况下,缩进的作用就只剩下让代码变的整洁了。
    Python是门超级简洁的语言,发明者定是觉得用{}太丑了,所以索性直接不用它,那怎么能区分代码块呢?答案就是强制缩进。
    Python的缩进有以下几个原则:
    顶级代码必须顶行写,即如果一行代码本身不依赖于任何条件,那它必须不能进行任何缩进
    同一级别的代码,缩进必须一致
    官方建议缩进用4个空格,当然你也可以用2个,如果你想被人笑话的话
      
          多分支:
        if 条件:
          满足条件执行代码
        elif 条件:
          上面的条件不满足就走这个
        elif 条件:
        上面的条件不满足就走这个
        elif 条件:
          上面的条件不满足就走这个
        else:
          上面所有的条件不满足就走这段
        
        例子:要求用户输入0-100的数字后,正确打印他的对应成绩
        score = int(input("输入分数:"))
        if score > 100:
            print("我擦,最高分才100...")
        elif score >= 90:
            print("A")
        elif score >= 80:
            print("B")
        elif score >= 60:
            print("C")
        elif score >= 40:
            print("D")
        else:
            print("太笨了...E")
        
    21、流程控制——while
      while 条件:
        循环体
      break用于完全结束一个循环,跳出循环体执行循环后面的语句
      continue和break有点类似,区别在于continue只是终止本次循环,接着还执行后面的循环,break则完全终止循环
      while...else...:while 后面的else 作用是指,当while 循环正常执行完,中间没有被break 中止的话,就会执行else后面的语句
                    
     代码1:
    count = 0
    while count <= 100:  # 只要count<=100就不断执行下面的代码
        print("loop ", count)
        if count == 5: #只要count=5就跳出while循环
            break
        count += 1  # 每执行一次,就把count+1,要不然就变成死循环啦,因为count一直是0
    print("-----out of while loop ------")
    输出:
    loop 0 loop 1 loop 2 loop 3 loop 4 loop 5 -----out of while loop ------
    代码2:                
    count = 0
    while count <= 100:
        count += 1
        if count > 5 and count < 95:  # 只要count在6-94之间,就不走下面的print语句,直接进入下一次loop
            continue
        print("loop ", count)
    print("-----out of while loop ------")
    输出:
    loop 1 loop 2 loop 3 loop 4 loop 5 loop 95 loop 96 loop 97 loop 98 loop 99 loop 100 loop 101 -----out of while loop ------
    代码3:while 循环正常执行完,中间没有被break 中止的话,继续执行else后面的语句
    count = 0
    while count <= 5:
        count += 1
        if count == 3: pass
        print("Loop", count)
    else:
        print("循环正常执行完啦")
    print("-----out of while loop ------")
    输出:
    Loop 1 Loop 2 Loop 3 Loop 4 Loop 5 Loop 6 循环正常执行完啦 -----out of while loop ------
     代码4: 如果执行过程中被break啦,就不会执行else的语句啦              
    count = 0
    while count <= 5 :
        count += 1
        if count == 3:
            break
        print("Loop",count)
    else: #while循环没有break,则执行else语句
        print("循环正常执行完啦")
    print("-----out of while loop ------")
    输出:
    Loop 1 Loop 2 -----out of while loop ------

    22、相关练习

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

    n = 0
    
    while n < 10:
        n += 1
        if n == 7:
            print()
            n += 1 # continue
    
        print(n)

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

    n = 0
    sum = 0
    
    while n < 100:
        n += 1
        sum += n
        
    print(sum)

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

    n = 0
    sum = 0
    
    while n < 100:
        n += 1
        if n%2 == 1:
            sum += n
    
    print(sum)

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

    n = 0
    sum = 0
    
    while n < 100:
        n += 1
        if n%2 == 0:
            sum += n
    
    print(sum)

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

    n = 0
    sum = 0
    
    while n < 99:
        n += 1
        if n%2 == 1:
            sum += n
        else:
            sum -= n
    
    print(sum)

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

    n = 0
    NAME = '中国'
    PASSWD = 'China'
    
    while True:
        n += 1
        name = input("请输入您的用户名:")
        passwd = input("请输入密码:")
        if name == NAME and passwd == PASSWD:
            print("恭喜您登录成功!")
            break
        elif (name != NAME or passwd != PASSWD) and n < 3:
            print("用户名错误或密码错误,您还有%d次机会,请继续输入!" % (3-n))
            continue
        elif (name != NAME or passwd != PASSWD) and n == 3:
            print("用户名错误或密码错误,登录失败!")
            break
    n = 0
    NAME = '中国'
    PASSWD = 'China'
    
    while n < 3:
        n += 1
        name = input("请输入您的用户名:")
        passwd = input("请输入密码:")
        if name == NAME and passwd == PASSWD:
            print("恭喜您登录成功!")
            break
        elif n == 3:
            print("登录失败!")
        else:
            print("用户名错误或密码错误,您还有%d次机会,请继续输入!" % (3-n))
    n = 1
    NAME = '中国'
    PASSWD = 'China'
    
    while n <= 3:
        name = input("请输入您的用户名:")
        passwd = input("请输入密码:")
        if name == NAME and passwd == PASSWD:
            print("恭喜您登录成功!")
            break
        else:
            print("用户名错误或密码错误,您还有%d次机会,请继续输入!" % (3-n))
            if n == 3:
                flag = input("是否继续(y/n):").strip()
                if flag == 'y':
                    n = 0
        n += 1
    else:
        print('登录失败!')
  • 相关阅读:
    Mac idea 打不开
    git学习之git reset命令
    更改 macOS 用户帐户和个人文件夹的名称
    SpringBoot系列: 如何优雅停止服务
    windows环境下启动mongodb服务
    rocketMq4.2.0启动broker报错找不到或无法加载主类 FilesJavajdk1.8.0_101libdt.jar;C:Program]
    初创公司与成熟的公司各有什么利弊?有5年工作经验的人适合进那一个?(行业职位是一样的情况下)
    mac 10.15 国内如何安装brew
    Mac下SSH Key配置
    买苹果MacBook Pro ,有必要买care吗?
  • 原文地址:https://www.cnblogs.com/nzd123456/p/8946557.html
Copyright © 2011-2022 走看看