写在前面:
前几天看的b站的小甲鱼一直迟迟没有跟新,再者感觉自己思维混乱,没有头绪;最后也可能是因为自己毅力不行,因此,花费了200大洋在某网站(为避免打广告嫌疑就略去啦)上买了课,打算重新系统的学习,写这篇文章之前已经跟这个学习了一点,感觉比小甲鱼的视频逻辑性高,因此打算跟这个视频课程学下去
毕竟是氪了金的!!!
正文:
一、一些相关知识
1、python语言的发展:
1989年:Guido Van发明了ABC语言
1991年:发展成为python,python正式诞生
2000年:python2.0发布
2008年:python3.0发布,但是并不兼容2.0
2010年:python2.7作为python2.0的终结版本
至今:python3
2、关于语言的分类
高级语言根据计算机执行机制的不同分为两类:静态语言和脚本语言。
静态语言采用编译方式执行,脚本语言采用解释方式执行。
编译是将源代码转换成目标代码的过程,执行编译的计算机程序称为编译器
解释是将源代码逐句转换成目标代码同时逐句运行目标代码的过程,执行解释的计算机程序称为解释器。
显然,python属于脚本语言
3、python解释器的两个重要工具
IDEL:Python集成开发环境,用来编写和调试Python代码。
pip:Python第三方库安装工具,用来在当前计算机上安装第三方库。
4、编写python程序的三个方法
①python3.7.3shell:直接交互
②在shell中点击:file→new file→输入代码并保存为.py文件→run→run modle
③利用cmd命令行
注:没有安装Python解释器的操作系统无法直接运行Python程序,需要将Python源代码打包变成可执行文件,这个过程叫做“程序发布”
5、Python程序执行常见的错误
①出现unexpected indent错误
原因:出现了未知缩进
②出现invalid syntax错误
原因:语法格式错误
二、python的基本语法
1、程序的格式框架
①缩进
用来表示Python间的包含和层次关系
在if、while、for、def、class等关键字所在完整语句后通过英文冒号(:)结尾并在之后进行缩进,冒号表示后面的语句是属于上一句的。
>>> for i in range(10):
if i%2 ==0:
continue
print(i)
这里,continue就是表明是属于if的,那么到哪里就不属于if语句了呢?看缩进,显然,print(i)就不属于if语句,而属于for语句。
②注释
Python采用“#”表示一行注释的开始,多行注释需要在每行开始都使用“#”,文档注释是三个单引号(''')或双引号(""")。
print(200)
#print(300)
#print(400)
结果:
200
print(400)
'''
print(300)
print(500)
'''
结果:
400
③续行符:\
2、数据类型
计算机对数据进行运算时需要明确数据的类型和含义
①数字类型:有整形、浮点型和复数类型
②字符串类型:用' '或“ ”括起来
3、程序语句元素
①表达式
产生或计算新数据值的代码片段称为表达式,一般由数据和操作符等构成。
如:1 + 1 → 2 'a b c' + 'd e f' = 'a b c d e f'
②赋值语句
对变量进行赋值的一行代码被称为赋值语句。
语法格式:<变量> = <表达式>
③引用外部函数库
导入需要调用的其他模块,模块只能被导入一次,被导入模块中的函数代码并不会被自动执行,只能被当前模块主动调用,导入模块后,后续代码就可以使用这个模块中已定义的各种功能函数。
导入模块的两种方式:
(1)使用import语句
语法格式如下:
import<模块1>
...
import<模块n>
(2)from方式
from<模块名>import<函数名>
例子:
区别:
采用第一种方式,用户自定义的函数名字可以和库中函数的名字一样;
采用第二种方式,用户程序中不能用函数库中的名字定义函数。
4、其他语句
①分支语句:
包括单分支、二分支和多分支
单分支
if <条件>:
<语句块>
解释:任何能够产生True或False的语句都可以作为条件,当条件为真时,执行语句块中的内容。
二分支
if <条件>:
<语句块1>
else:
<语句块2>
解释:当条件为True时,执行语句块1;当条件为False时,执行语句块2。
②循环语句
循环包括:遍历循环和条件循环。
条件循环的基本过程:
while (<条件>):
<语句块1>
<语句块2>
解释:当条件为True时,执行语句块1,然后再次判断条件,当条件为False时,退出循环,执行语句块2。
三、python的基本输入输出
1、input()输入函数
使用方式:<变量> = input(<提示文字>)
注意:无论用户输入的是字符还是数字,input函数统一按照字符类型处理输出
>>> a = input("请输入一个数字")
请输入一个数字5
>>> print(a)
5
>>> type(a)
<class 'str'>
2、eval()
使用方式:<变量> = eval(<字符串>)
注意:去掉字符串最外侧的引号,并按照python语句方式执行去掉引号后的字符内容
>>> a = eval("1+3")
>>> print(a)
4
>>> eval("3")
3
>>> eval("book")
报错
Traceback (most recent call last):
File "<pyshell#6>", line 1, in <module>
eval("book")
File "<string>", line 1, in <module>
NameError: name 'book' is not defined
第一个可以显示3,第二个显示不了book,报错的原因在于,book啥也不是,python无法执行,而3是一个数字类型,可以执行,book没有引号,python认为不是字符串,不是字符串也不是数字类型,就只能是变量,但是也没有定义变量,所以出错。
改成这样就对了:
>>> eval(" 'book' ")
'book'
3、print()输出函数
使用方式:
①进输出字符串或变量:print(<待输出字符串>)
②仅用于输出一个或多个变量:print(<变量1>,(<变量2>),(<变量n>))
③用于混合输出字符串与变量值:print(<输出字符串模板>.format((<变量1>,<变量2>, ,<变量n>)))
>>> print(2)
2
>>> print("python")
python
>>> a = "python"
>>> print(a,a,a,a)
python python python python
>>> print("欢迎来到{},这里是{}".format('简书','python'))
欢迎来到简书,这里是python
注意:print函数输出文本时默认在最后增加一个换行,若不希望在最后增加换行,或者是想要输出其他内容,可以对print()函数的end参数进行赋值
四、基本数据类型:
1、整数类型
有4种进制表示:十进制、二进制、八进制和十六进制
那python是如何识别一个数字的哪个进制呢?需要用户添加引导符号
二进制:0b或0B
八进制:0o或0O
十进制:无引导符号
十六进制:0x或0X
>>> a = 1010
>>> a
1010
>>> a = 0b1010
>>> a
10
>>> a = 0o1010
>>> a
520
进制转换:
转为二进制:bin()
转为八进制:oct()
转为十进制:Int()
转为十六进制:hex()
>>> a = bin(10)
>>> a
'0b1010'
>>> a = oct(520)
>>> a
'0o1010'
2、浮点数类型
浮点数类型与数学中实数的概念一致,表示带有小数的数值。Python语言中要求浮点数类型必须带有小数部分,小数部分可以是0。有两种表示方法:一般表示法和科学计数法。浮点数的表示只有十进制的表示
>>> pow(1010,25)
1282431995017233613592752029298389976325673030025010000000000000000000000000
>>> pow(1010.0,25)
1.2824319950172337e+75
由上可以看出,整数的运算精度比浮点数运算精度高
总的来说:浮点数的表示是有bug的
如:
>>> 0.1+0.2
0.30000000000000004
受限于计算机表示浮点数使用的存储宽度,计算的二进制数并不是0.1和0.2而是计算机内部最接近0.1和0.2的二进制数。求得的数反映到十进制表示上,就会产生一个不确定尾数,至于尾数是多少,计算机内部会根据二进制运算确定产生。
解决办法:round函数
round(x,d)是一个四舍五入函数,x为操作数,d为指定保留的小鼠位数
>>> round(2.8493,3)
2.849
>>> round(2.8497,3)
2.85
3、复数类型
用a+bj表示
>>> a = 3 + 7j
>>> a
(3+7j)
复数类型中实部和虚部都是浮点类型,对于复数z,可以用z.real和z.imag分别获得实数部分和虚数部分。
>>> z = 3+6j
>>> z.real
3.0
>>> z.imag
6.0
4、数字的基本运算
x + y :求和
x - y :求差
x * y :求积
x / y :求商,结果为浮点数
x // y :求两数的整数商
x % y :求余
x ** y :x的y次幂
-x :相反数
+x :本身
基本规则:
整数和浮点数混合运算,输出结果浮点数;
整数之间运算,产生结果类型与操作符相关;
整数或浮点数与复数运算,输出结果是复数。
5、数字的函数运算:
函数 | 描述 | 其他 |
---|---|---|
abs(x) | x的绝对值 | 用于计算整数或浮点数x的绝对值。该函数也可以计算复数的绝对值,值为斜边的长度 |
divmod(x,y) | (x//y,x%y) | 无 |
pow(x,y)或 pow(x,y,z) | x* * y或( x* * y)%z | 无 |
round(x)或round(x,d) | 对x四舍五入,保留d位小数 | 对整数或浮点数x进行四舍五入运算。若遇到5,采用“奇进偶不进"的方式运算。 |
floor() | 向下取整 | 无 |
ceil() | 向上取整 | 无 |
int() | 直接去掉小数部分 | 无 |
>>> abs(6+8j)
10.0
>>> round(0.6)
1
>>> round(1.6)
2
>>> round(0.5)
0
>>> round(1.5)
2
遇到5奇进偶不进
>>> from math import ceil
>>> ceil(4.9)
5
>>> from math import floor
>>> floor(9.8)
9
6、操作符:
逻辑操作符 | 操作含义 | 比较操作符 | 操作含义 | 位运算操作符 | 操作含义 | 示例 | ||
---|---|---|---|---|---|---|---|---|
and | 与 | < | 小于 | & | 按位与 | a&b | ||
or | 或 | <= | 小于等于 | I | 按位或 | aIb | ||
not | 非 | >= | 大于等于 | ~ | 按位取反 | ~a | ||
> | 大于 | ^ | 按位异或 | a^b | ||||
== | 等于 | << | 左移 | a<<b | ||||
!= | 不等于 | >> | 带符号右移 | a>>b |
不管是逻辑运算符还是比较运算符,都是用来判断条件是真是假,返回bool值。
位运算操作符主要是与计算机存储数据有关
7、真值表:
对象 | 值 |
---|---|
“” | 假 |
“里面有东西” | 真 |
0 | 假 |
[]空列表 | 假 |
()空元组 | 假 |
{}空字典 | 假 |
None | 假 |