python_learn 四

写在前面:
      前几天看的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参数进行赋值

image.png

image.png
image.png

image.png

四、基本数据类型:
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
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第一部分 初识Python语言 第1章 程序设计基本方法 1.1 计算机的概念 计算机是根据指令操作数据的设备,具...
    不脱发的程序员阅读 1,135评论 0 1
  • 一、python入门 1. python介绍 1.1 python可运用范围 1.1.1 脚本、小工具 1.1.2...
    三观正_1e5f阅读 1,312评论 0 10
  • 基于《Python语言程序设计基础(第2版)》 第一部分 初识Python语言 第1章 程序设计基本方法 1.1 ...
    柄志阅读 27,538评论 4 44
  • Python-开篇 Python是一种通用的解释型,交互式,面向对象的高级编程语言。它是由Guido van Ro...
    泥人冷风阅读 762评论 0 0
  • 一、PyCharm的基本使用1.1、注释:为了方便自己或者其他人查看单行注释:用 # 号单行注释多行注释: 用 ...
    IIronMan阅读 8,899评论 3 18