【黑马程序员】Python文件、异常、模块、包

文章目录

  • 文件操作
    • 文件编码
      • 什么是编码
      • 为什么要使用编码
    • 文件的读取
      • open
      • model常用的三种基础访问模式
      • 读操作相关方法
    • 文件的写入
      • 注意
      • 代码示例
  • 异常
    • 定义
    • 异常捕获
      • 捕获指定异常
      • 捕获多个异常
      • 捕获所有异常
      • 异常else
      • 异常finally
    • 异常的传递
  • python 模块
    • 定义
    • 模块的导入
      • import模块名
      • from 模块名 import 功能名
      • 使用*导入time的sleep功能
      • 使用as给特定功能加上别名
    • 自定义模块
      • 创建自定义模块举例
      • `__name__` 变量
      • `__all__` 变量
      • 注意
  • Python包
    • 自定义包
      • 定义
      • 创建包
      • 导入包
        • 使用import导入
        • 使用from import导入
        • 导入模块中
    • 安装第三方包
      • 常见第三方包
      • 安装第三方包
  • 综合练习
    • 需求
    • 实现

文件操作

文件编码

什么是编码

  • 编码就是一种规则集合,记录了内容和二进制间进行互相转换的规则

  • 最常用的是UTF-8编码

为什么要使用编码

  • 计算机内部保存的都是0和1,所以需要将内容全部转换为0和1才能识别

  • 读取时需要将计算机中保存的0和1转为内容

文件的读取

open

  • 语法
open(name, mode, encoding)
name    要打开的目标文件名的字符串
mode    打开文件的模式:只读、写入、追加
encoding    编码格式,推荐使用UTF8

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

在这里插入图片描述

读操作相关方法

  • read方法
文件对象.read(num)
num    表示要从文件中读取的数据长度,单位是字节,如果没有传,读取文件中所有的数据
  • readlines():可以按照行的方式把整个文件的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素

  • readline()读取文件的一行

  • for循环读取文件行

  • close()关闭文件对象

  • with open语法:用于打开文件并在使用完毕后自动关闭文件

在这里插入图片描述

  • 代码示例
# *_*coding:utf-8 *_*
# 打开文件
f = open("./read_file.py", 'r', encoding="UTF-8")
# 读取文件
print(f'读取50个字节的结果{f.read(50)}')
# 在程序中多次调用read,下一次会从上一次读的偏移结尾继续读
print(f'读取全部字节的结果{f.read()}')# readlines读取文件的全部行,封装到列表中
print(f'读取文件的全部行{f.readlines()}')# readline一次读取文件一行
line1 = f.readline()
line2 = f.readline()
line3 = f.readline()
print(f'第一行数据是:{line1}')
print(f'第二行数据是:{line2}')
print(f'第三行数据是:{line3}')# 关闭文件
f.close()# for循环读取文件行
for line in open("./read_file.py", "r"):print(line)# with open语法
with open("./read_file.py", "r", encoding="UTF-8") as f:print(f'{f.readlines()}')

文件的写入

注意

  • 直接调用write方法,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区

  • 当调用flush的时候,内容会真正写入文件

  • 目的:避免频繁磁盘操作,导致效率下降

  • close方法内置了flush功能

  • w模式

    • 文件不存在则创建

    • 文件存在则清空

  • a模式

    • 文件不存在则创建

    • 文件存在则追加尾部写

代码示例

# *_*coding:utf-8 *_*# open打开文件,使用覆盖写操作
f = open("test.txt", "w", encoding="UTF-8")
# write写入
f.write("123456789")
# flush刷新
f.flush()
# 关闭文件
f.close()# open打开文件,使用追加写操作
f = open("test1.txt", "a", encoding="UTF-8")
# write写入
f.write("123456789")
# flush刷新
f.flush()
# 关闭文件
f.close()

异常

定义

  • 当检测到一个错误时,Python解释器就无法继续运行了,反而出现一些错误的提示,这就是所谓的异常

异常捕获

  • 作用:提前假设某处会出现异常,做好提前准备,当真的出现异常时,可以有后续手段

  • 基本语法

try:可能发生异常的代码块
except:出现异常后的代码块
  • 代码示例:打开一个不存在的文件
try:f = open("xxx.txt", 'r')
except:print("open file err")

捕获指定异常

  • 注意:

    • 如果尝试执行的代码的异常类型和捕获的异常类型不一致,则无法捕获异常

    • 一般try下面只放一行尝试执行的代码

  • 语法:

try:print(name)
except NameError as e:print('name变量名称未定义错误')
  • 代码示例
try:print(name)
# as e是给NameError类型起别名
except NameError as e:print('name变量未定义错误')

捕获多个异常

  • 代码示例
# 捕获多个异常
try:print(name)
# as e是给NameError类型起别名,e中记录了异常的具体信息
except (NameError, ZeroDivisionError) as e:print('name变量未定义错误或者除0异常')

捕获所有异常

  • 代码示例
# 捕获所有异常
try:print(name)
# 方式一:通过捕获Exception异常,Exception是顶级异常
except Exception as e:print('name变量未定义错误')try:print(name)
# 方式二:不指定具体的异常直接捕获
except:print('name变量未定义错误')

异常else

  • else表示的是如果没有异常要执行的代码

  • 代码示例

# 异常else
try:print(name)
# as e是给NameError类型起别名,e中记录了异常的具体信息
except (NameError, ZeroDivisionError) as e:print('name变量未定义错误或者除0异常')
else:print("未发生异常")

异常finally

  • finally表示的是无论是否异常都要执行的代码

  • 代码示例

# 异常finally
try:print(name)
# as e是给NameError类型起别名,e中记录了异常的具体信息
except (NameError, ZeroDivisionError) as e:print('name变量未定义错误或者除0异常')
else:print("未发生异常")
finally:print("总会执行我")

异常的传递

  • 异常是具有传递性的

  • 内层的异常如果没有被捕获会沿着调用链一直向上抛直到main函数

  • 代码示例

# *_*coding:utf-8 *_*def func1():print("func1 start")1 / 0print("func1 end")def func2():print("func2 start")func1()print("func2 end")def main():try:func2()except Exception as e:print(e)main()

python 模块

定义

  • Python模块是一个Python文件,以.py结尾,模块能定义类、函数和变量,模块里面也能包含可执行的代码

  • 作用:模块就是一个工具包

模块的导入

  • 模块在使用之前需要先导入

  • 语法

[from 模块名] import [模块||变量|函数|*] [as 别名]
  • 常用组合方式
import 模块名
from 模块名 import 类、变量、方法等
from 模块名 import *
import 模块名 as 别名
from 模块名 import 功能名 as 别名

import模块名

  • 基本语法
import 模块名
import 模块名1,模块名2
  • 代码示例
# 导入时间模块
import timeprint("satrt")
# 程序睡眠3s
time.sleep(3)
print("end")

from 模块名 import 功能名

  • 代码示例
from time import sleepprint("satrt")
# 程序睡眠3s
sleep(3)
print("end")

使用*导入time的sleep功能

  • 代码示例
from time import *print("satrt")
# 程序睡眠3s
sleep(3)
print("end")

使用as给特定功能加上别名

  • 代码示例
import time as tprint("satrt")
# 程序睡眠3s
t.sleep(3)
print("end")

自定义模块

创建自定义模块举例

  • 创建my_module.py
def test(a, b):print(a + b)
  • 创建test_my_module.py
import my_modulemy_module.test(1, 2)

__name__ 变量

  • 在当前模块中执行时,才会生效,外部导入时不会执行

  • 代码示例

def test(a, b):print(a + b)if __name__ == '__main__':test(1, 1)

__all__ 变量

  • 如果一个模块中有__all__变量,当使用from xxx import *,时只能导入这个列表中的元素,没有all时默认导入的是所有,有all时只导入all中的

  • 创建my_module.py

__all__ = ['test1']def test(a, b):print(a + b)def test1(a, b):print(a + b)
  • 创建test_my_module.py
from my_module import *test1(1, 1)
# NameError: name 'test' is not defined
# test(1, 1)

注意

  • 不同模块,同名的功能,如果都被导入,那么后导入的会覆盖先导入的

Python包

自定义包

定义

  • 从物理上看,包就是一个文件夹,在该文件夹下包含了一个__init__.py文件,该文件夹可用于包含多个模块文件

  • 从逻辑上看,包的本质依然是模块

创建包

  • 右键New->Python Package->输入包名

  • 编写对应模块文件

    • 新建my_module1.py
    # *_*coding:utf-8 *_*
    def info_print1():print('my_module1')
    
    • 新建my_module2.py
    # *_*coding:utf-8 *_*def info_print2():print('my_module2')
    

导入包

使用import导入
  • my_package同级创建一个test_my_package.py文件
# *_*coding:utf-8 *_*
import my_package.my_module1
import my_package.my_module2# 包中的my_module1模块的info_print方法
my_package.my_module1.info_print1()
# 包中的my_module2模块的info_print方法
my_package.my_module2.info_print2()
使用from import导入
from my_package import my_module1
from my_package import my_module2my_module1.info_print1()
my_module2.info_print2()
导入模块中
from my_package.my_module1 import info_print1
from my_package.my_module2 import info_print2info_print1()
info_print2()

安装第三方包

常见第三方包

在这里插入图片描述

安装第三方包

  • 命令:pip install 包名

  • 示例

在这里插入图片描述

综合练习

需求

在这里插入图片描述

实现

  • 新建my_utils包

  • 新建str_utils.py文件

# *_*coding:utf-8 *_*def str_reverse(s):reversed(s)return sdef substr(s, x, y):return s[x:y]
  • 新建file_utils.py文件
# *_*coding:utf-8 *_*def print_file_info(file_name):try:f = open(file_name, "r", encoding='UTF-8')except Exception as e:print(e)finally:f.close()def append_to_file(file_name, data):f1 = open(file_name, 'a', encoding='UTF-8')f1.write(data)f1.close()
  • 测试:在my_utils同级新建test_my_utils.py
# *_*coding:utf-8 *_*from my_utils import str_util
from my_utils import file_utilprint(f'反转后的结果是:{str_util.str_reverse("abc")}')
print(f'取子串后后的结果是:{str_util.substr("123456789", 2, 7)}')file_util.print_file_info("aa.txt")
file_util.append_to_file("aa.txt", "这是一条追加内容")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/746373.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Chroma向量数据库报错Delete of nonexisting embedding ID: 123-sql

Vanna使用ChromaDB_VectorStore时,删除训练数据,指定错误的id后,导致的错误Delete of nonexisting embedding ID: 123-sql 使用delete函数后,经常会出现如下错误,暂未修复,但是不妨碍使用: De…

python 基础知识点(蓝桥杯python科目个人复习计划63)

今日复习内容:做题 例题1:蓝桥骑士 问题描述: 小蓝是蓝桥王国的骑士,他喜欢不断突破自我。 这天蓝桥国王给他安排了N个对手,他们的战力值分别为a1,a2,...,an,且按顺序阻挡在小蓝的前方。对于这些对手小…

注意力机制Attention、CA注意力机制

一、注意力机制 产生背景: 大数据时代,有很多数据提供给我们。对于人来说,可以利用重要的数据,过滤掉不重要的数据。那对于模型来说(CNN、LSTM),很难决定什么重要、什么不重要,因此…

vue3+ts动态表单渲染,antd的useForm改造

let fieldList: any getFormFields(fieldInfo.coreNavigationList[0].list[0].list,fieldInfo.positionCodeRespVO,isCanBeUpdateProcess.value,isDetail.value 1); fieldInfo数据格式: {"name": "默认模板","status": "ENA…

1688跨境无货源铺货API上货API跨境电商无货源对接

1688 API 接入说明 点此获取API地址 调用示例: 参数说明 通用参数说明 version:API版本key:调用key,测试key:test_api_keyapi_name:API类型[item_get,item_search]cache:[yes,no]默认yes,将调用缓存的数据,速度比较快result_type:[json,xml…

day-20 跳跃游戏 II

思路&#xff1a;用一个数字来存储到对应索引i的最少跳跃次数&#xff0c;ans[j]Math.min(ans[j],ans[i]1) code: class Solution {public int jump(int[] nums) {int nnums.length;int ans[]new int[n];for(int i0;i<n;i){ans[i]Integer.MAX_VALUE;}ans[0]0;for(int i0;i…

从VUCA到BANI时代:如何打造企业韧性经营?

当下&#xff0c;国际局势波谲云诡&#xff0c;国内经济也充满着不确定性&#xff0c;给众多企业带来了前所未有的压力。 然而&#xff0c;在这充满挑战的时刻&#xff0c;一些企业凭借强大的数字化能力&#xff0c;展现出惊人的经营韧性和逆流而上的精神&#xff0c;实现了业绩…

电梯机房秀 系列二

上次小伍带大家看了部分机房的照片&#xff0c;并且简单介绍了一下电梯能量回馈装置&#xff0c;小伙伴们表示很新奇&#xff0c;没看够&#xff0c;今天小伍又来了&#xff0c;带大家看一下电梯能量回馈装置到底安装在电梯什么位置。跟着小伍去看看吧。Lets go&#xff01; 电…

科技回顾,飞凌嵌入式受邀亮相第八届瑞芯微开发者大会「RKDC2024」

2024年3月7日~8日&#xff0c;第八届瑞芯微开发者大会&#xff08;RKDC2024&#xff09;在福州举行&#xff0c;本届大会以“AI芯片AI应用AloT”为主题&#xff0c;邀请各行业的开发者共启数智化未来。 本届大会亮点颇多&#xff0c;不仅有13大芯片应用展示、9场产品和技术论坛…

学生时期学习资源同步-1 第一学期结业考试题8

原创作者&#xff1a;田超凡&#xff08;程序员田宝宝&#xff09; 版权所有&#xff0c;引用请注明原作者&#xff0c;严禁复制转载

GIS入门,GeoServer介绍,GeoServer如何发布WMTS地图服务,GeoServer如何自动切割瓦片

GeoServer介绍 GeoServer是一个开源的地理空间数据服务器,它允许用户共享、处理和编辑地理空间数据。GeoServer基于Java开发,可以将各种空间数据格式(如Shapefile、PostGIS、Oracle Spatial等)转换为标准的地理空间数据服务,比如Web Map Service (WMS)、Web Feature Serv…

超分辨率(2)--基于EDSR网络实现图像超分辨率重建

目录 一.项目介绍 二.项目流程详解 2.1.构建网络模型 2.2.数据集处理 2.3.训练模块 2.4.测试模块 三.测试网络 一.项目介绍 EDSR全称Enhanced Deep Residual Networks&#xff0c;是SRResnet的升级版&#xff0c;其对网络结构进行了优化(去除了BN层)&#xff0c;省下来…

避免阻塞主线程 —— Web Worker 示例项目

前期回顾 迄今为止易用 —— 的 “盲水印“ 实现方案-CSDN博客https://blog.csdn.net/m0_57904695/article/details/136720192?spm1001.2014.3001.5501 目录 CSDN 彩色之外 &#x1f4dd; 前言 &#x1f6a9; 技术栈 &#x1f6e0;️ 功能 &#x1f916; 如何运行 ♻️ …

《JAVA与模式》之工厂方法模式

系列文章目录 文章目录 系列文章目录前言一、工厂方法模式二、工厂方法模式的活动序列图三、工厂方法模式和简单工厂模式前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码…

【个人记录】CentOS7安装MySQL 5.7和libmysqlclient.so.20

记录 之前使用MariaDB 发现使用的libmysqlclient.so是18版本的&#xff0c;一些程序需要20版本的库&#xff0c;查了一下需要安装5.7以上版本的才有libmysqlclient.so.20&#xff0c;这里简单记录一下怎么安装。 安装MySQL 5.7 Yum源 yum install -y https://repo.mysql.com…

如何用SMU数字源表测试apd管的暗电流

01 APD工作原理 APD雪崩光电二极管的工作原理是基于光电效应和雪崩效应&#xff0c;当光子被吸收时&#xff0c;会产生电子空穴对&#xff0c;空穴向P区移动&#xff0c;电子向N区移动&#xff0c;由于电场的作用&#xff0c;电子与空穴相遇时会产生二次电子&#xff0c;形成雪…

串行通信——IIC总结

一.什么是IIC&#xff1f; IIC&#xff08;Inter-Integrated Circuit&#xff09;也称I2C&#xff0c;中文叫集成电路总线。是一个多主从的串行总线&#xff0c;由飞利浦公司发明的通讯总线&#xff0c;属于半双工同步传输类总线&#xff0c;仅由两条线就能完成多机通讯&#…

【解读】区块链和分布式记账技术标准体系建设指南

大家好&#xff0c;这里是苏泽。一个从业Java后端的区块链技术爱好者。 今天带大家来解读这份三部门印发的行业建设指南《区块链和分布式记账技术标准体系建设指南》 原文件可查看P020240112840724196854.pdf (www.gov.cn) 以下是个人解读&#xff0c;如有纰漏请指正&#xff…

【系统架构师】-第16章-嵌入式系统架构设计理论与实践

1、嵌入式系统发展 第一阶段&#xff1a;单片微型计算机 (SCM) 阶段&#xff0c;即单片机时代&#xff0c;五操作系统 第二阶段&#xff1a;微控制器 (MUC) 阶段&#xff0c;有简单操作系统 第三阶段&#xff1a;片上系统 (SoC)&#xff0c;兼容各种微处理器 第四阶段&…

软件测试 —— 测试用例设计报告

写出测试网站的测试用例&#xff0c;测试网站具体内容可看团购网站系统需求说明书1.2.doc 一、流程1&#xff1a;注册→登录 图1&#xff1a;注册->登录流程图 1、 使用场景设计法设计测试用例 1&#xff09; 找出基本流和备选流 基本流注册用户-成功登录系统备选流1注册…