🔥博客主页: A_SHOWY
🎥系列专栏:力扣刷题总结录 数据结构 云计算 数字图像处理 力扣每日一题_
六天时间系统学习Python基础总结,目前不包括可视化部分,其他部分基本齐全,总结记录,学过C++和java等并用过一些py学起来快很多。另推荐某站学习课程链接在下方,讲解清晰。
【黑马程序员python教程,8天python从入门到精通,学python看这套就够了】https://www.bilibili.com/video/BV1qW4y1a7fU?p=115&vd_source=2a2d1efdeba6d2eedfe2fd5940c5f1be



用m.n控制数据的宽度和精度,m控制宽度,n控制小数点精度“%5d”、“%5.2f”、“%.2f”
如果m比数字本身的宽度还要小,就不会生效
f”内容{变量}”
不会理会类型,不会做精度控制
表达式:一条有明确结果的代码语句,如1+1或者name=”张三”,age=1+1,type(“abcde”)
获取键盘的输入,可以使用input(提示信息),用于给用户提示。无论键盘输入什么类型,获取的都是字符串类型,需要自己类型转换。
- print("请告诉我你是谁")
- name=input()
- print("我知道了,你是:%s"%name)
- name=input("请告诉我你是谁?")
- print("我知道了,你是:%s"%name)
例:

- user_name = input("请输入您的姓名")
- user_type = input("请输入您的用户类型")
- print(f"{user_name},您是尊贵的{user_type}用户,欢迎您的光临")
布尔类型的字面量:True,False
变量名称=布尔类型字面量
比较运算符:是否相等==,是否不相等!=,是否大于>,是否小于<,>=,<=
if 要判断的条件:
条件成立时,要做的事情
if 条件:
满足条件要做的事情
else:
不满足条件要做的事情
多个条件的判断,上一个满足后面的就不会判断了,可以在条件判断中直接写input
if 条件1:
条件1成立时,要做的事情
elif 条件2:
条件2成立时,要做的事情
elif 条件3:
条件3成立时,要做的事情
else:
所有条件都不满足要做的事情

- import random
- num = random.randint(1,2)
- print(num)
While 条件:
条件满足时,做的事情1
条件满足时,做的事情2
.......
只要条件满足,会无限循环执行
条件需要布尔类型,需要设置终止的条件
不换行:
print("hello",end='')
print("world",end='')
制表符:\t,多字符串整齐对齐
print("hello\tworld")
print("itheima\tbest")
例:打印99乘法表
- i = 1
- while(i <= 9):
- j = 1
- while(j <= i):
- print(f"{i} * {j} = {i * j}\t",end = '')
- j += 1
- print()
- i += 1
for 临时变量 in 待处理数据集(序列)
循环满足条件时执行的语句

无法定义循环条件,只能从被处理的数据集中依次取出处理,无法构建无限循环
range(1, 9) 不生成列表,而是一个表示从1到8(不包括9)的范围的对象。在Python 3中,range() 函数返回的是一个可迭代的对象,而不是立即生成所有元素的列表。
如果需要将其转换为列表,可以使用 list() 函数
序列:指内容可以一个个依次取出的类型:字符串,列表,元组
range语句可以获得一个简单的数字序列
range(num)
获取一个从0开始,到num结束的数字序列(不含num本身)
Range(num1,num2)
从num1开始到num2结束的数字序列,不含num2本身
Range(num1,num2,step)
从num1开始到num2结束的数字序列(不含num2本身),数字之间的步长是step
临时变量,在编程规范上,作用范围,只限定在for循环内部
- for i in range(5):
- print(i)
- print(i)
如果想访问这个临时变量i,可以在for循环之前定义一个i=0,后面只是一遍遍覆盖这个i
for循环和while循环可以互相嵌套使用
例子:99乘法表
- for i in range(1,10):
- for j in range(1,i + 1):
- print(f"{i}*{j} = {i * j}\t",end = '')
- print()
中断本次循环,直接进入下一次循环

Continue语句只可以控制它所在的循环临时中断

break关键字用于直接结束循环
break语句也只控制他所在的循环

- import random
- i = 1
- money = 10000
- for i in range(1,21):
- t = random.randint(1,10)
- if t < 5:
- print(f"员工{i},绩效分{t},不发工资,下一位")
- continue
- if (t >= 5):
- if money <= 0:
- print("工资发完了,下个月领取吧")
- break
- else :
- money -= 1000
- print(f"向员工{i}发工资1000元,账户余额还剩余{money}元")
def 函数名(传入参数):
函数体
return 返回值
传入参数和return可以省略,函数必须先定义后使用
函数的调用:
函数名(参数)
传入参数:在函数进行计算的时候,接受外部提供的数据
可以不使用参数,也可以使用任意N个参数
变量=函数(参数)
返回值会给到这个变量
函数体一遇到return就结束了,后面的代码不会执行了。
无返回值的函数实际上是返回了None这个字面量
使用场景:
函数返回值;
在if判断中,None等同于False;
None也用于声明无初始内容的变量。

写上”””回车会自动出来前面的格式,鼠标放在调用的括号上会出来说明文档。
一个函数里又调用了另外一个函数
作用域:变量在哪里可用,在哪里不可用
局部变量:定义在函数体内部的变量,只在函数体内部生效
临时保存数据,在函数调用完后立即销毁变量
全局变量:在函数体内、外都能生效的变量
将变量定义在函数的外面
global关键字

如果没有global,函数B里的num还是局部变量
一个容器容纳多份数据,每一份数据称为一个元素,每个元素可以是任意类型的数据。
列表、元组、字符串、集合、字典

列表中的元素可以是不同类型,支持嵌套


获取对应位置的元素:
列表[下标索引]

在python中如果将函数定义为class(类)的成员,函数就会称之为:方法。方法和函数只是使用格式不同。

列表的方法:

语法:列表.index(元素)
语法:列表[下标]=值
语法:列表.insert(下标,元素),在指定的下标位置,插入指定的元素
语法:列表.append(元素),将指定元素,追加到列表的尾部
或者语法:列表.extend(其他的数据容器),将其他的数据容器的内容取出,依次追加到列表尾部
语法一:del 列表[下标]
语法二:列表.pop[下标],还能用变量接收删除的元素
语法:列表.remove(元素)
语法:列表.clear()
语法:列表.count(元素)
统计列表元素个数,这个不叫方法
语法:len(列表)
列表的while循环遍历
遍历:将容器内的元素依次取出进行处理的行为
列表的for循环遍历,for 临时变量 in 数据容器:临时变量进行处理
While循环适用于任何想要循环的场景
for循环适用于遍历数据容器的场景或简单的固定次数循环场景
- #遍历两种写法
- list = [21,25,21,23,22,20]
- index = 0
- while index < len(list):
- ele = list[index]
- print(f"元素{ele}")
- index += 1
-
-
- for x in list:
- ele = x
- print(ele)
列表是可以被修改的;元组一旦定义完成,就不可以修改

通过下标索引取出内容和list一样

元组里嵌套的list里的内容可以修改
字符串是一个无法修改的数据容器
常用操作

语法:字符串.index(字符串)
字符串.rindex(字符串)找到的是最后一个字符串出现的位置
语法:字符串.replace(字符串1,字符串2)
将字符串内的全部字符串1,替换为字符串2
注意:不是修改了字符串本身,而是得到了一个新字符串
语法:字符串.split(分隔符字符串)
功能:按照指定的分隔符字符串,将字符串划分为多个字符串,并存入列表对象中
注意:字符串本身不变,而是得到了一个列表对象
strip()去除开头和结尾的空格和换行符

语法:字符串.count(字符串)
len(字符串)
字符串的遍历也支持while循环和for循环
将序列中的元素连接成字符串,可以指定元素和元素之间连接的字符川
语法:separator.join(iterable)
不加分隔符:"".join(words)
zfill 是字符串对象的一个方法,它用于在字符串的左侧(即字符串的开头)用零填充字符串,使其达到指定的宽度
语法:str.zfill(width)
将整数转换为二进制表示,会自动返回一个二进制的字符串,这个字符串以"0b"为前缀,后面跟着二进制表示的数字
序列:内容连续、有序,可使用下标索引的一类数据容器。列表、元组、字符串都可以视为序列。
切片:从一个序列中,取出一个子序列。
语法:序列[起始下标:结束下标:步长]
起始下标留空视作从头开始,结束下标留空(含)视作截取到结尾。结束下标(不含)表示何处结束。步长省略默认为1
步长1表示挨个取,步长2表示每次跳过一个取,步长N表示每次跳过N-1个取,步长为负数表示反向取。
[:-2]表示从头开始取到倒数第二个(不包含)
切片操作不会影响序列本身,而是得到一个新的序列
列表可以修改、支持重复元素且有序;元组、字符串不可修改、支持重复元素且有序。
集合不支持重复元素且内部无序。不支持下标索引访问。集合可以修改

常用操作

语法:集合.add(元素)
语法:集合.remove(元素)
语法:集合.pop()
语法:集合.clear()
语法:集合1.difference(集合2)
功能:取出集合1里有而集合2没有的
结果:得到一个新的集合,集合1和集合2不变
语法:集合1.difference_update(集合2)
功能:在集合1内删除和集合2相同的元素
结果:集合1被修改,集合2不变
语法:集合1.union(集合2)
功能:将集合1和集合2合成新集合
结果:得到新集合,集合1和集合2不变
语法:len(集合)
集合不支持下标索引所以不能用while循环,但是可以用for循环
common = set1 & set2,返回的是包含两个集合中相同集合的元素
该方法会修改原始集合,将可迭代对象中的元素添加到集合中,如果有重复的元素,则只保留一个副本。
- set1 = {1, 2, 3}
- tuple1 = (2, 3, 4)
- set1.update(tuple1)


字典的key不可以重复,不可以使用下标索引,但是可以用key获得对应的value
语法:字典[key]
字典的嵌套:Key和value可以是任意数据类型(key不能为字典)
字典的常用操作

语法:字典[key]=value,结果:字典被修改,新增元素
语法:字典[key]=value,结果:字典被修改,元素被更新(效果不同取决于key存不存在)
语法:字典.pop(key),结果:获得指定key 的value,同时字典被修改,指定key的数据被删除
语法:字典.clear()
语法:字典.keys(),结果:得到字典中的全部key;字典.values(),得到字典中的全部value


语法:len(字典)

Python在遍历字典时不允许修改字典元素,会报错RuntimeError: dictionary changed size during iteration,可以改为for k in list(my_dict.keys()):



(1)遍历
(2)len(容器)
(3)max(容器)
(4)min(容器)
(5)通用类型转换
①list(容器),容器转换成列表。字符串转列表将字符串每个元素都取出来作为列表的每个元素。字典将value抛弃掉只剩下key。
②tuple(容器),容器转换成元组。
③str(容器),容器转换成字符串。“[1,2,3,4,5]”“(1,2,3,4,5)”“{1,2,3,4,5}”,字典的value会保存
④set(容器),容器转换成集合。
⑤dict(容器),容器转换为字典。将其他序列转化成字典的时候 对这个序列有要求,这个序列得是二维的, 内层序列得有两个元素
[['语文', 77], ['数学', 78]]
sorted(容器,reverse=True),传入True就是从小到大,传入False就是从大到小。排序的结果会全部变成列表,字典会丢失value
ASCII码表:大小写英文字母,数字,特殊符号都有对应的ASCII码
字符串进行比较就是基于ASCII码值大小进行比较的


逗号隔开的可以返回不同的类型
使用方式不同,四种常见的参数使用方式
调用函数时根据函数定义的参数位置来传递参数
函数调用时通过“键=值”形式传递参数

为参数提供默认值,调用函数时可以不传该默认参数的值,注意:所有位置参数必须在默认参数前。默认参数必须统一都在最后面

用于不确定调用的时候会传递多少个参数
分为:
参数数量不一定多少


前面我们学的都是接受数据作为参数传入:
数字、字符串、字典列表元组等
也可以函数本身作为参数传入另一个函数内

是一种计算逻辑的传递,而非数据的传递
函数的定义中
def关键字,可以定义带有名称的函数,可以反复使用
lambda关键字,可以定义匿名函数(无名称),只能临时使用一次
语法:
lambda 传入参数:函数体(只能写一行代码)

文本文件使用编码技术(密码本)将内容翻译成0和1存入计算机中。
编码技术:翻译的规则,记录了如何将内容翻译成二进制,以及如何将内容翻译回可识别内容。
计算机中可用编码:UTF-8、GBK、Big5等
什么是文件?文本文件、视频文件、音频文件、图像文件、可执行文件
对文件的操作:打开、关闭、读、写
文件的操作步骤:打开-读写-关闭




Readlines:读取全部行,封装到列表
Read():读取全部,到字符串
多次调用read,后面的read会在上一次read的结尾处开始读
\n是回车换行符




例子;文件的读取,统计里面“chenzi”的数量
-
- f = open('E:\guozi.txt','r',encoding = 'UTF-8')
- count = 0
- for line in f:
- line = line.strip()
- words = line.split(" ")
- print(words)
- for word in words:
- if word == "chenzi":
- count += 1
- print (count)
- f.close()

write方法,内容并未真正写入文件,会在内存中的缓冲区,调用flush的时候才会真正写入文件。避免频繁操作硬盘。
f.write写入的必须是字符串不能是别的。
Close()内置了flush()

a模式,文件不存在会创建文件
文件存在会追加写入文件,在原有内容后面继续写入,可以使用“\n”来换行
程序运行过程中出现了错误(Bug)
基本语法:
try:
可能发生错误的代码
except:
如果出现异常执行的代码
基本语法:
try:
print(name)
except NameError(异常) as e(别名):
print(‘name变量名称未定义错误’)

try:
except Exception as e:
else表示的是如果没有异常要执行的代码
try:
except Exception as e:
else:
表示无论是否异常都要执行的代码,例如关闭文件
try:
except Exception as e:
else:
finally:
异常具有传递性

模块(module),是一个python文件,以.py结尾,模块能定义函数,类和变量,也可能包含可执行的代码。一个模块就是一个工具包
一般写在开头的位置
中括号是表示可以写可以不写

基本语法:
(1)
import 模块名 模块里所有功能都能用
import 模块名1,模块名2
模块名.功能名()
(2)
from 模块名 import 功能名 模块里只有这一个功能能用
功能名()
(3)
from 模块名 import * *表示全部的意思,和(1)的区别不需要用.
(4)

注意:当导入多个模块的时候,且模块内有同名功能,当调用同名功能,调用到的是后面导入模块的功能。

__main__变量所提供的功能:运行这个模块文件的时候name被自动赋值了main所以会运行,但去另一个用这个模块的文件中运行就不会了。


__all__作用在*上
Python包就是一个文件夹,在该文件夹下包含了一个__init__.py文件(创建包会默认自动创建的文件),这个文件存在才说明这是一个包。

(1)方式一

或者用 from 包名 import 模块名,这样不用写包名.了
下面三种方法

(2)方式二
通过__all__变量控制import *
在__init__.py文件里定义__all__变量

使用pip程序即可,打开命令提示符程序,在里面输入:pip install包名称
国内网站安装命令:
![]()
在pycharm里安装

点加号搜索安装就行,如果想用国内的就在选项勾选然后输入
![]()
等待更新
生活中或是程序中,我们都可以使用设计表格、生产表格、填写表格的形式组织数据
使用对象组织数据
设计类

创建对象

对象属性赋值




定义在类内部的函数称之为方法

调用的时候self关键字可以不用理会,不用写这个参数
现实世界的事物由属性和行为组成,类也可以包含属性和行为,所以类很适合用来描述现实世界。
面向对象编程:设计类,基于类创建对象,由对象做具体的工作。

构造方法也是成员方法,self关键字不要忘记,构造方法内访问成员变量,要用self。
__init__构造方法,是pythontip类内置的方法之一,这些内置的类方法,各自有各自的特殊功能,这些内置方法我们称之为:魔术方法。

当类对象需要变成字符串就会通过字符串方法去变成字符串的形式,如果不写就会输出内存地址





封装是:将现实世界的属性和行为,封装到类中描述为成员变量和成员方法。
私有成员:
私有成员变量:变量名以__开头
私有成员方法:方法以__开头(两个下划线)
私有成员无法被类对象使用,但是可以被类中的其他成员使用。

class 类名(父类名):
类内容体
一个类继承多个父类
class 类名(父类1,父类2,......,父类N):
类内容体
多个父类中,如果有同名的方法或者属性,先继承的优先级高于后继承(左边的高)
pass关键字的作用:占位语句,用于保证定义的完整性,表示无内容,空的意思。
子类继承父类的成员属性和方法后,如果对其不满意,可以进行复写

调用父类同名成员

注意:只可以在子类内部调用父类的同名成员,子类的实体类对象调用默认是调用子类复写的。
为什么需要类型注解?
在代码中涉及数据交互的地方,提供数据类型的注解(显示的说明)
主要功能:
帮助IDE对代码进行类型推断,协助做代码提示;帮助开发者自身对变量进行类型注释
支持:


为变量设置注释,显示的变量定义,一般无须注解


类型注解只是提示性的,不是强制性的,不会报错


、


多态:多种状态,即完成某个行为时,使用不同的对象会得到不同的状态。



抽象类就好比定义一个标准,包含了一些抽象的方法,要求子类必须实现。