4万字【Python高级编程】保姆式教学,Python大厂高频面试题解析

本文详细讲解了Python的高级编程技巧,包括自定义模块的创建与调用,模块与包的作用,以及如何进行模块与包的测试。深入探讨了Python中包的创建、导入与使用,如导入子模块、使用别名等。此外,还介绍了文件处理的基础操作,如读写文件、文件属性与方法。文章还涵盖了错误处理、多线程和多进程的知识,以及如何通过Thread类和继承实现线程。最后,讲解了容器、可迭代对象、生成器和列表推导式,强调了生成器在性能优化中的重要作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


[](

)4.自定义模块

每个人都能生成自定义模块来进行调用,自定义模块就是Python文件,我们写代码时创建的Python文件就相当于1个模块。

注意点:被调用的模块尽量放在当前Python文件相同目录下,否则导入时要声明所在文件夹才能导入。

例子:自定义1个模块,在另一个Python文件中进行调用。

新建1个名为module1的Python文件,代码如下:

def fun1(a,b) : #实现a+b并输出结果

print(a+b)

相同目录下新建另一个Python文件,调用module1.py这个模块:

import module1

module1.fun1(20,30)

运行当前Python文件结果:

50


[](

)5.模块的测试

每个模块导入的时候都默认被执行一遍,但同时在模块内部又存在着很多的内部测试代码,为了避免导入模块时执行了模块内部的测试代码,于是就牵扯到一个方法:

很多模块在内部都有测试方法:

if name == “main”:

代码1

这个方法能够实现一个功能,在模块中执行的话,就会执行代码1的代码,在其他文件导入该模块的时候,则不会执行代码1的代码,所以一般模块内部的测试都放在了代码1当中。

为什么?神奇的点就在于__name__,它在当前文件中执行的结果是__main__,在其他文件导入时执行的结果是模块名,所以利用这一点,用上if语句就能判断模块执行到底是在当前文件执行还是被导入执行。

举例:

新建1个Python叫module1,作为模块,代码如下:

print(name) #打印__name__

执行结果:

main

再新建1个Python文件,导入刚才建好的module1.py模块:

import module1

执行结果:

module1

在当前文件的执行和被导入时执行,结果是不一样的,所以它成为了模块的内部测试方法。

注意点:在自定义的模块中,不建议写while循坏,不然导入的过程中一直在执行模块里面的while循坏,可能会跳不出来,也就是一直在导入模块,其他代码执行不到。


[](

)👳(二)包


[](

)1.定义

包就是将有联系的模块放在同一个文件夹下,并且该文件夹里有“init.py”这个文件,这个文件夹就叫做包。

包的特征:

1.包也是对象

2.必须有__init__.py文件

3.init.py文件是包的构造方法,控制着包的导入行为,一般是个空包

4.包里面不仅可以有模块,还可以有子包


[](

)2.包的创建

在Pycharm软件中新建1个项目文件,创建完成后,打开Pycharm创建1个项目文件夹→点击文件夹→右键弹出选项→New→Python Package→完成创建,创建的新文件夹就是包,里面自动创建了init文件。

在这里插入图片描述


[](

)3.包的导入

常规导入方法主要有2种。

方法1:import 包名.模块名.目标

方法2:import 包名.子包.模块名.目标

这里所说的目标可以是变量、函数等等对象,具体的在下面会讲到。


[](

)4.包的使用

使用形式1:常规使用1

import 包名.模块名

包名.模块名.功能

举例:创建1个包,在另一个.py文件中使用,要求.py文件不包含在创建的包内。

步骤1,打开Pycharm新建一个项目,创建1个包,命名为demo,包里面新建1个.py文件,命名为my_module,代码如下:

a = 100

def fun1():

print(“这是1个包”)

步骤2,打开另1个.py文件,导入已创建的包

import demo.my_module

print(demo.my_module.a)

demo.my_module.fun1()

执行结果:

100

这是1个包

使用形式2:常规使用2

from 包名 import 模块名

模块名.功能

模块名.变量

举例:我沿用上面已经创建好的demo包,直接在步骤2中修改代码,用这个新方式去导入包并使用。

from demo import my_module

print(my_module.a)

my_module.fun1()

执行结果是一样的:

100

这是1个包

使用形式3:另起别名并使用

import 包名.模块名 as 别名

别名.功能

别名.变量

上面使用形式1中可能有人会发现,导入模块后的使用不太方便,又要包名又要模块名的,能不能简单点?当然可以,直接给包里的模块另起1个缩短的别名,后面直接用别名就可以了。

沿用上面的使用形式1的例子,这里我就不改动步骤1了,我直接在步骤2中进行另起别名。

import demo.my_module as n1 #另起别名为n1

print(n1.a)

n1.fun1()

执行结果:

100

这是1个包

结果是一样的,但如果代码比较长的话,使用别名会方便很多。

当然了,这里也可以用使用形式2的方式导入包并另起别名,使用时用别名就可以了,这个方式我就不举例了,你们自己可以去试试。

使用方式4:导入某个功能

from 包名.模块名 import 功能1

功能1

这里我也沿用已创建好的包,直接在另一个.py文件中进行使用。

from demo.my_module import fun1

fun1()

执行结果:

这是1个包

使用方式5:导入所有功能

在模块导入的时候我们介绍了import * 这个方式去导入模块里面的所有功能,在这里也可以这么入导入包里面的模块的所有功能。

举例,名叫“demo”包里面有1个模块叫“hhhh”,模块的代码如下:

def fun1():

print(“这是功能1”)

def fun2():

print(“这是功能2”)

然后我们在另一个.py文件中调用一下;

from demo.hhhh import *

fun1()

fun2()

执行结果:

这是功能1

这是功能2

6.关于all的使用

关于__all__的使用在模块的时候有介绍过,那是控制可以被导入的功能列表,但在包里面,__all__是控制可以被导入的模块列表,即声明哪些模块可以被导入。

包里面的__all__是在__init__文件中声明的,而不是在哪个模块中写的。

举例:一个包里面有多个模块,其中被all声明的模块可以被导入,不声明的不可以被导入。

步骤1,在名为demo的包里面有hhhh和my_module两个模块,但在int文件中被all声明只有hhhh文件可以使用,int文件的代码如下:

all = [

“hhhh” # hhhh模块允许被导入

]

步骤2,在新的.py文件中导入demo包里面的hhhh和my_module两个模块:

from demo import * #导入包里面的所有模块

hhhh.fun1() #调用hhhh模块的fun1功能,输出“这是功能1”

my_module.fun1() #调用my_module模块的fun1功能,输出“这是1个包”

执行结果:

在这里插入图片描述

很明显,虽然用 * 导入了所有模块,但被all声明可导入的hhhh模块是可以被使用的,没被all声明的my_module模块是不能使用的,系统无

法识别。


[](

)👳(三)模块与包的作用


1.提高代码的可重用性。好用的代码不止你1个人可以用,很多人都可以重复使用它。

2.提高代码的可读性。如果所有的代码都放在1个.py文件中,那代码就太长了,增加了理解和维护难度,所以可以把一些常用的代码封装成包和模块,起1个望文生义的名字,需要的时候直接用就行,减少了代码的数量,提高了可读性。

3.减少代码的冗余。模块里面封装的一些方法,我们直接给参数去使用就可以了,不用把方法再写一遍,占用内存,也就减少了代码的冗余。


[](

)👳(四)第三方库的安装


Python虽然有很多自带的模块和包,简称内置模块,但只会使用内置模块还不够,毕竟内置模块有限,我们经常会用到第三方的库,这个时候学习怎么安装第三方的库(包)是很必要的。

今天来介绍3种第三方模块与包的安装方法。

[](

)1.通过pip安装

可以通过包管理命令pip去进行第三模块与包的下载和安装,前提是你安装的Python是照着我前面在【Python基础入门】那篇文章所讲的方式去安装,所有的选项都勾选了,这样你就不用配置环境变量了,首先查看一下你的pip是否能用。

方法:WIN+R调出运行窗口→输入cmd→如果出现下面的pip信息则是可以使用pip

在这里插入图片描述

如果出现红字提示“cmd中 ’pip‘不是内部或外部命令,也不是可运行的程序或批处理文件”,那么你就手动配置一下环境变量吧,实在不行就回过头跟着我说的安装Python的步骤去重新装吧。

回到pip如何安装第三方模块与包的问题,首先我们得知道我们要安装的第三方模块与包是叫什么名字,比如Pillow这个第三方库,这是Python下非常强大的处理图像的工具库,安装方法是:

1.WIN+R调出运行窗口

2.输入cmd

3.输入 pip install Pillow

4.等待下载和安装的完成

请添加图片描述

有时候会出现很多红字提示下载失败,这个很正常,原因可能是:

(1).pip版本过低,升级一下pip版本,在黑窗口输入:python -m pip install -U pip

(2)网络不好,多下载几遍就可以了


[](

)2.通过Pycharm安装

通过pip安装是不需要打开软件的,但我们也可以通过Pycharm进行安装,方法如下:

点击左上角的 File → Settings → Project:项目名 → Python interpreter → 点击 + →

输入你想安装的包名,选择你看上的 → 点击 Install Package → 等待下载和安装

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


[](

)3.通过渠道下载.whl文件安装

可以通过官网等渠道去搜索和下载你想要的包,官网:https://pypi.org/ ,搜索你要下载的第三方库,比如说Pillow这个库,直接搜就可以了:

在这里插入图片描述

然后选择你要下载的文件,比如Pillow8.3.2这个版本,进入下载页面,点击 Download files。

在这里插入图片描述

进去之后有很多的版本型号,建议选择与你符合的版本,否则可能装不了,这里要注意Python版本、系统和电脑的位数。

在这里插入图片描述

比如说我的Python装的是3.9.6的,所以我下的是cp39里面的,电脑是64位,用的是Windows系统,所以我下的版本是 Pillow-8.3.2-cp39-cp39-win_amd64.whl 这个文件。

在这里插入图片描述

下载好之后,WIN+R 打开命令行输入CMD,在黑窗口中输入 pip install 文件路径下的文件名,比如我下载后存放的路径是D:\谷歌浏览器,所以我在黑窗口输入的代码是:

pip install D:\谷歌浏览器\Pillow-8.3.2-cp39-cp39-win_amd64.whl

然后回车进行安装,等待安装完成。

在这里插入图片描述


[](

)三、文件处理

================================================================

[](

)💼(一)文件的定义和操作


计算机中的文件通常是指计算机硬盘为载体的、存储在计算机中的信息集合,主要的表现形式为视频、音频、图片以及文档四类,比如执行性文件.exe、文档文件.txt、网页文件.html等等。

在这里插入图片描述


[](

)💼(二)文件的基本操作


在现实中,我们对文件进行操作可以大致总结为“打开→操作(阅读、删除、修改等)→保存→关闭”,在Python当中依然是如此,在用Python开始文件操作之前,我们先学几个方法。

1.open(name,mode) ----打开文件

这是Python打开文件的方法,用于打开一个文件,返回的是一个文件对象。

name指的是文件名,一定要写全,何为写全?就是要写清楚 存储路径+文件名+后缀 。

为何要写这么全?因为就算是相同的存储路径下,文件名相同的文件也可能不止一个,只要后缀不一样,计算机是允许存在同名文件,所以不写全的话,计算机是不知道你指的是谁

mode是打开文件的模式,默认是r,也就是只读的方式。mode的方式有很多,比如读、写等等,后面我们会讲到。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值