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的一大特色,强制缩进,目的是为了让程序知道,每段代码依赖哪个条件,如果不通过缩进来区分,程序怎么会知道,当你条件成立后,去执行哪些代码呢?
    其他的语言里,大多数通过{}来确定代码块,比如C\C++、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('登录失败!')

 

posted @ 2018-04-25 18:52  你知道  阅读(339)  评论(0编辑  收藏  举报