当前位置:   article > 正文

Python 入门教程详细版全集(两周速成)_pathyon

pathyon

一、初始Python

打开CMD(命令提示符)程序,输入Python回车。然后,在里面输入代码回车即可立即执行。

 Tip1:找不到“命令提示符”程序在哪里?

使用快捷键:win + r;打开运行框,输入cmd后回车即可打开命令提示符程序

Tip2:安装python的时候,务必勾选:add python 3.10to PATH的选项;

二、常见的值类型

Python中常用的有6种值(数据)的类型

字符串
字符串(string),又称文本,是由任意数量的字符如中文、英文、各类符号、数字等组成。所以叫做字符的串;

字符串需要用双引号(")包围起来被引号包围起来的,被引号包围起来的,都是字符串。

注释:在程序代码中对程序代码进行解释说明的文字。

  1. # 我是单行注释
  2. print("Hello World")
  3. # 注意:#号和注释内容一般建议以一个空格隔开
'
运行
  1. # 多行注释:以一对三个双引号引起来("""注释内容""")来解释说明一段代码的作用使用方法
  2. """
  3. Hello
  4. World
  5. !
  6. """
  7. print("Hello")
  8. print("World")
  9. print("!")
'
运行

字符串在Python中有多种定义形式:

单引号定义法:name=‘Lotus’
双引号定义法:name ="Lotus"
三引号定义法:name ="""Lotus""”

三引号定义法,和多行注释的写法一样,同样支持换行操作。使用变量接收它,它就是字符串
不使用变量接收它,就可以作为多行注释使用.

字符串拼接
如果我们有两个字符串(文本)字面量,可以将其拼接成一个字符串,通过+号即可完成,如:

  1. print("hello"+"world")
  2. # 输出:hello world
'
运行

面量和变量或变量和变量之间会使用拼接,如

  1. name = 'lotus'
  2. print("my name :" + name + ", hello world")
  3. #输出:my name :lotus, hello world
'
运行

字符串格式化

% 表示:我要占位
s表示:将变量变成字符串放入占位的地方
所以,综合起来的意思就是:我先占个位置,等一会有个变量过来,我把它变成字符串放到占位的位置;多个变量占位,变量要用括号括起来,并按照占位的顺序填入。

字符串格式化-数字精度控制

m,控制宽度,要求是数字(很少使用),设置的宽度小于数字自身,不生效·.n,控制小数点精度,要求是数字,会进行小数的四舍五入示例:
%5d:表示将整数的宽度控制在5位,如数字11,被设置为5d,就会变成:[空格][空格][空格]11,用三个空格补足宽度。
%5.2f:表示将宽度控制为5,将小数点精度设置为2
小数点和小数部分也算入宽度计算。如,对11.345设置了%7.2f后,结果是:[空格][空格111.35。2个空格补足宽度,小数部分限制2位精度后,四舍五入为.35

 

三、变量

变量:在程序运行时,能储存计算结果或能表示值的抽象概念。简单的说,变量就是在程序运行时,记录数据用的。

变量的定义格式  变量名称 = 变量的值

标识符命名规则-内容限定

标识符命名中,只允许出现:英文、中文(不推荐使用中文)、数字(数字不可以开头)、下划线

  1. #定义一个变量,用来记录钱包余额
  2. money=50
  3. #通过print语句,输出变量记录的内容
  4. #格式:print(内容1,内容2,内容3,.....)
  5. print("钱包还有:” ,money)

 变量为两类:局部变量和全局变量

局部变量指的是变量的作用范围(变量在哪里可用,在哪里不可用)

所谓局部变量是定义在函数体内部的变量,即只在函数体内部生效

所谓全局变量,指的是在函数体内、外都能生效的变量

  1. # 定义全局变量a
  2. num =100
  3. def testA():
  4. print(num)#访问全局变量num,并打印变量num存储的数据
  5. def testB():
  6. print(num)#访问全局变量num,并打印变量num存储的数据
  7. testA()
  8. testB()
  9. #100
  10. # 100

四、运算符

 算术(数学)运算符

赋值运算符

复合赋值运算符

 比较运算符

布尔类型的数据,不仅可以通过定义得到,也可以通过比较运算符进行内容比较得到

五、常用语句 

type()语句的使用方式
1.在print语句中,直接输出类型信息:

  1. print(type(666))
  2. print(type(11.345))
  3. """输出
  4. <class 'int'>
  5. <class 'float'>
  6. """
'
运行

2.用变量存储type()的结果(返回值):

  1. string_type =type("HELLO")
  2. int_type =typě(666)
  3. float_type = type(11.345)
  4. print(string_type)
  5. print(int_type)
  6. print(float type)
  7. """<class 'str'>
  8. <class 'int'>
  9. <class 'float'>
  10. """

常见的转换语句



 

input语句(函数)

数据输出:print           数据输入:input

使用一个变量接收(存储)input语句获取的键盘输入数据即可

  1. print("请告诉我你的名字")
  2. name = input()
  3. print("我知道了,你是:%s" %name)
  4. # 请告诉我你是谁
  5. # lotus
  6. # 我知道了,你是:lotus
'
运行

Tip3:无论键盘输入什么类型的数据,获取到的数据永远都是字符串类型
 

while循环语句

1.while的条件需得到布尔类型,True表示继续循环,False表示结束循环
2.需要设置循环终止的条件,如i+=1配合i<100,就能确保100次后停止,否则将无限循环
3.空格缩进和if判断一样,都需要设置

  1. i = 1
  2. while i <= 100:
  3. print(f"{i}")

for循环语句
除了while循环语句外,Python同样提供了for循环语句。两者能完成的功能基本差不多,但仍有一些区别:
·while循环的循环条件是自定义的,自行控制循环条件
for循环是一种”轮询”机制,是对一批内容进行”逐个处理”for循环语句,本质上是遍历:序列类型

  1. #定义字符串name
  2. name ="itheima'
  3. # for循环处理字符串
  4. for x in name:
  5. print(x)

range语句

语法1:
range(num)
获取一个从0开始,到num结束的数字序列(不含num本身)
如range(5)取得的数据是:[0,1,2,3,4]

语法2:
range(num1,num2)
获得一个从num1开始,到num2结束的数字序列(不含num2本身)如,range(5,10)取得的数据是:[5,6,7,8,9]
语法3:
range(num1,num2,step)
获得一个从num1开始,到num2结束的数字序列(不含num2本身)
数字之间的步长,以step为准(step默认为1)
如,range(5,10,2)取得的数据是:[5,7,9]

continue语句

continue关键字用于:中断本次循环,直接进入下一次循环continue可以用于:for循环和while循环,效果一致

  1. foriin range(1,100):
  2. 语句 1
  3. 语句 2
  4. #在循环内,遇到continue就结束当次循环,进行下一次所以,语句2是不会执行的。

六、函数

如果将函数定义为class(类)的成员,那么函数会称之为:方法

  1. # 函数的定义:
  2. def 函数名(传入参数):
  3. 函数体
  4. return 返回值
  5. 函数的调用:
  6. 函数名(参数)

 传入参数的功能是在函数进行计算的时候,接受外部(调用付)提供的数据

  1. #实现1+2相加的函数
  2. def add():
  3. result=1+2
  4. print(f"1 + 2的结果是:{result}")
  5. #定义实现两数相加的函数
  6. def add(x, y):
  7. result=x+yprint(f"{x}+{y}的结果是:{result}")
  8. # 调用函数
  9. add(56)

函数嵌套

  1. #定义函数func_b
  2. def func_b():
  3. print("---2---")
  4. #定义函数func_a,并在内部调用func_b
  5. def func_a():
  6. print("---1---")
  7. #嵌套调用func_b
  8. func_b()
  9. print("---3---")
  10. # 调用函数func_a
  11. """
  12. ---1---
  13. ---2---
  14. ---3---
  15. """
'
运行

函数多个返回值

  1. def test return():
  2. return 1,2
  3. x,y = text_return ()
  4. print(x) # 结果1
  5. print(y) # 结果2
  6. # 按照返回值的顺序,写对应顺序的多个变量接收即可
  7. # 变量之间用逗号隔开
  8. # 支持不同类型的数据return

位置参数

注意:
传递的参数和定义的参数的顺序及个数必须一致

位置传递

注意:
传进的所有参数都会被args变量收集,它会根据传进参数的位置合并为一个元组(tuple),args是元组类型,这就是位
置传递

  1. def user info(*args):
  2. print(args)
  3. #('TOM',)
  4. user_info('TOM')
  5. #('TOM',18)
  6. user info('TOM'18)

关键字参数:函数调用时通过“键=值”形式传递参数
作用:可以让函数更加清晰、容易使用,同时也清除了参数的顺序需求

注意:函数调用时,如果有位置参数时,位置参数必须在关键字参数的前面,但关键字参数之间不存在先后顺序。

关键字传递:

参数是“键=值”形式的形式的情况下,所有的“键=值”都会被kwargs接受,同时会根据“键=值”组成字典.

  1. def user info(**kwargs):
  2. print(kwargs)
  3. #'name':TOM','age':18,id':110}
  4. user info(name='TOM',age=18,id=110)

缺省参数:缺省参数也叫默认参数,用于定义函数,为参数提供默认值,调用函数时可不传该默认参数的值(注意:所有位置参数必须出现在默认参数前,包括函数定义和调用).作用:当调用函数时没有传递参数,就会使用默认是用缺省参数对应的值.

注意:
函数调用时,如果为缺省参数传值则修改默认参数值,否则使用这个默认值

不定长参数
不定长参数:不定长参数也叫可变参数,用于不确定调用的时候会传递多少个参数(不传参也可以)的场景作用:当调用函数时不确定参数个数时,可以使用不定长参数
不定长参数的类型:
①位置传递
②关键字传递

函数作为参数传递

  1. def test_func(compute):
  2. result=compute(12)
  3. print(result)
  4. def compute(x,y):
  5. return x+y
  6. test func(compute)
  7. # 函数compute,作为参数,传入了testfunc函数中使用。
  8. # 结果:3

test_func需要一个函数作为参数传入,这个函数需要接收2个数字进行计算,计算逻辑由这个被传入函数决定compute函数接收2个数字对其进行计算,compute函数作为参数,传递给了testfunc函数使用
最终,在test func函数内部,由传入的compute函数,完成了对数字的计算操作
所以,这是一种,计算逻辑的传递,而非数据的传递
.
就像上述代码那样,不仅仅是相加,相见、相除
等任何逻辑都可以自行定义并作为函数传入。

 None类型
如果函数没有使用return语句返回数据,那么函数有返回值是None;

Python中有一个特殊的字面量:None,其类型是:<class'WoneType)>无返回值的函数,实际上就是返回了:None这个字面量。

  1. def say_he11o():
  2. print("He11o...")
  3. #使用变量接收say_he11o函数的返回值
  4. result]= say_he11o()
  5. #打印返回值
  6. print(result)
  7. #打印返回值类型
  8. print(type(result))
  9. # 结果None
  10. #结果<class'NoneType'>
  11. #None可以主动使用return返回,效果等同于不写return语句:
  12. def say he1lo():
  13. print("He71o...")
  14. return None
  15. #使用变量接收say_hel1o函数的返回值
  16. result=say_he1lo()
  17. #打印返回值
  18. print(result)
  19. # 结果None

lambda匿名函数


七、数据容器


一种可以容纳多份数据的数据类型,容纳的每一份数据称之为1个元素每一个元素,可以是任意类型的数据,如字符串、数字、布尔等.

数据容器根据特点的不同,如:
·是否支持重复元素、是否可以修改、是否有序,等分为5类,分别是:
列表(list)、元组(tuple)、字符串(str)、集合(set)、字典(dict)

列表的定义:

  1. #嵌套列表
  2. my_1ist =[123]日[456]]
  3. print(my_list)
  4. print(type(my list))
  5. # [[1,2,3],[4,5,6]]
  6. # <class 'list'>

1.列表的查询功能

2.修改特定位置(索引)的元素值:

3.插入元素

4.追加元素

1)语法:列表.append;

2)   语法:列表.extend;

5.删除元素

语法:列表.remove(元素)

6.清空列表列表.clear()

7.统计元素个数len(列表)

元组:定义元组使用小括号,且使用逗号隔开各个数据,数据可以是不同的数据类型

  1. #定义3个元素的元组
  2. t1=(1'Hello'True
  3. #定义1个元素的元组
  4. t2=('Hello',) #注意,必须带有逗号,否则不是元组类型
  5. # 注意:元组只有一个数据,这个数据后面要添加逗号

元组的相关操作

字符串:无法修改的数据容器。

下标引索

字典

数据容器的通用统计功能

通用类型转换

八、文件

文件的操作步骤

① 打开文件
② 读写文件
③ 关闭文件

注意:可以只打开和关闭文件,不进行任何读写

open()打开函数

mode常用的三种基础访问模式

read 函数

for循环读取文件行

  1. for line in open("python.txt","r"):
  2. print(line)
  3. # 每一个line临时变量,就记录了文件的一行数据

close()关闭文件对象

  1. f= open("python.txt","r")
  2. f.close()
  3. # 最后通过close,关闭文件对象,也就是关闭对文件的占用
  4. # 如果不调用close,同时程序没有停止运行,那么这个文件将一直被python程序占用。

with open 语法

  1. with open("python.txt", "r") as f:
  2. f.readlines()
  3. # 通过在with open的语句块中对文件进行操作
  4. #可以在操作完成后自动关闭close文件,避免遗忘掉close方法

九、异常

基本语法:

  1. try:
  2. 可能发生错误的代码
  3. except:
  4. 如果出现异常执行的代码

 

捕获指定的异常

  1. try:
  2. print(name)
  3. except NameError as e:
  4. print('name变量名称未定义错误')
  5. # 捕获多个异常
  6. # 当捕获多个异常时,可以把要捕获的异常类型的名字,放到except后,并使用元组的方式进行书写。
  7. try:
  8. print(1/0)
  9. except (NameError,ZeroDivisionError):
  10. print("ZeroDivision错误...)

十、对象

创建类对象的语法: 对象=类名称()

成员变量和成员方法(函数)

self关键字是成员方法定义的时候,必须填写的。

  1. class student:
  2. name =None #学生的姓名
  3. age = None #学生的年龄
  4. def say hi(self):
  5. print(f"Hi大家好,我是{self.name}")
  6. #self关键字是成员方法定义的时候,必须填写的。
  1. # 设计一个闹钟类
  2. class Clock:
  3. id = None #序列化
  4. price = None #价格
  5. def ring(self):
  6. import winsound
  7. winsound.Beep(20003000)
  8. #构建2个闹钟对象并让其工作
  9. clock1=Clock()
  10. clock1.id ="003032"
  11. print(f"闹钟ID:{clock1.id},价格:{clock1.price}")
  12. clock1.ring()

Python类可以使用:_init()方法,称之为构造方法。

在创建类对象(构造类)的时候,会自动执行。
在创建类对象(构造类)的时候,将传入参数自动传递给init方法使用。

  1. class student:
  2. name = None
  3. age = None
  4. tel = None
  5. definit_(self,name,age,tel):
  6. self.name =name
  7. self.age = age
  8. print("student")
  9. stu=student("周杰轮”,31,"18500006666")

内置方法(魔术方法)

1._init_ 构造方法    2._str_字符串方法  3._it_ 小于、大于符号比较

4._le_小于等于、大于等于符号比较  5._eq_=符号比较

面向对象的三大特性

封装 继承 多态

私有成员

私有成员变量:变量名以开头(2个下划线)

私有成员方法:方法名以开头(2个下划线)

私有成员无法被类对象使用,但是可以被其它的成员使用。

  1. class Phone:
  2. ——current voltage =0.5 #当前手机运行电压
  3. def _keep_single_core(self):
  4. print("让CPU以单核模式运行”)
  5. def ca11 by_5g(se1f):
  6. if self. current_voltage >=1:
  7. print("5g通话已开启")
  8. else:
  9. self._keep_single_core()
  10. print("电量不足,无法使用5g通话,并已设置为单核运行进行省电。")

继承

单继承

多继承

多个父类中,如果有同名的成员,那么默认以继承顺序(从左到右)为优先级。

  1. class Phone:IMEI= None#序列号
  2. producer = None#厂商
  3. def ca11_by_5g(se1f):
  4. print("5g通话”)
  5. class NFCReader:
  6. nfc_type =“第五代"
  7. producer = "HM"
  8. def read_card(self):
  9. print("该取NFC卡")
  10. def write_card(self):
  11. print("写入NFC卡")
  12. class Remotecontrol:
  13. rc_type ="红外通控”
  14. def control(self):
  15. print("红外暹控开启")
  16. c1ass MyPhone(phone, NFcReader, Remotecontro]):
  17. pass

复写::在子类中重新定义同名的属性或方法即可,

调用父类同名成员

方法1:
·调用父类成员
使用成员变量:父类名,成员变量
使用成员方法:父类名.成员方法(self)
方式2:
使用super()调用父类成员
使用成员变量:super().成员变量
使用成员方法:super().成员方法()

Union 类型

使用Union[类型,…, 类型],可以定义联合类型注解

多态

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/822623
推荐阅读
相关标签
  

闽ICP备14008679号