当前位置: 首页 > news >正文

零基础学习Python(六)

1. 元类的应用

使用元类给对象添加一个固有属性author:

对类名进行限定,要求类名必须是大写字母开头:

class MetaC(type):def __init__(cls, name, bases, attrs):if not name.istitle():raise TypeError("类名必须是大写字母开头~")return type.__init__(cls, name, bases, attrs)

限制类实例化时只能传递关键字参数:

class MetaC(type):def __call__(cls, *args, **kwargs):if args:raise TypeError("仅支持关键字参数~")return type.__init__(cls, name, bases, attrs)

禁止类进行实例化:

class NoInstance(type):def __call__(cls, *args, **kwargs):raise TypeError("该类不允许被实例化对象!")

不允许该类创建对象,那么可以使用静态方法或者类方法来使用该类:

只允许类实例化一个对象:

class SimpleInstance(type):def __init__(cls, *args, **kwargs):cls.__instance = Nonereturn type.__init(cls, *args, **kwargs)def __call__(cls, *args, **kwargs):if cls.__instance is None:cls.__instance = type.__call__(cls, *args, **kwargs)return cls.__instance

可以看到这个唯一的对象保存在类的_SimpleInstance__instance的变量里。

2. 抽象基类

抽象基类不能被实例化,只能被继承,其子类必须实现其定义的抽象方法。

from abc import ABCMeta, abstractmethod
class Fruit(metaclass=ABCMeta):def __init__(self, name):self.name = name@abstractmethoddef good_for_health(self):pass

要想定义一个抽象基类,只需要指定其metaclass为ABCMeta即可,要定义一个抽象方法,使用abstractmethod装饰器即可。

class Banana(Fruit):def good_for_health:print("~")

3. 模块和包

一个.py文件就是一个模块,导入模块的三种方式(假设模块名为hello):

import hello
# 此时调用模块函数,使用hello.say_hi()、hello.say_hello()
from hello import say_hi, say_hello
# 此时可能会有命名冲突的问题,即两个模块有同名函数/对象,那么后导入的会覆盖先导入的
import hello as h
# 通过as命名别名可以解决命名冲突的问题,此时调用函数使用h.say_hi()、h.say_hello()

模块在导入过程中,会从头到尾执行一遍模块的所有代码,因此如果不使用if __name__ == "__main__":将一些测试语句包裹起来,那么在导入模块的时候会执行一些没必要的代码。 因为当一个.py文件/一个模块被当做脚本(而不是导入)被独立执行的时候,它的__name__属性就会被赋值为“__main__”。如果一个.py文件/一个模块被导入的时候,它的__name__属性就是模块的名称。

python的包是多个模块的集合,是一个文件夹,里面有必须的一个__init__.py文件,标识这个文件夹是一个python包。导入模块的方式变为:import 包名.模块名。

可以对__init__.py文件进行修改,用于对包进行初始化的操作:

print(f"__init__.py 被调用,此时 __name__ 的值是 {__name__}")

此时打印的是包名。导入包的模块,模块中的__name__的值是包名.模块名。

可以在__init__.py文件里定义全局变量,但是包里的模块不能直接访问这个全局变量(可以编写函数访问全局变量,但是运行该模块会报错),要通过包外的其他模块引用该模块,才可以进行访问。

例如在__init__.py文件中添加两个全局变量:

包内的模块尝试访问x:

这是因为包内模块是看不到这个包的。在包外模块访问包的全局变量是ok的

 在__init__.py里还可以导入包里的某个模块,这样其他模块在导入这个包的时候就会自动导入模块:​​​​​​​ ​​​​​​​

​​​​​​​

导入模块时,使用from 模块名 import *会造成命名空间的污染,为此,python提供了__all__属性来解决这一问题,通过__all__属性来指定特定的模块内的变量和函数才能被导入:

__all__ = ["say_hello", "x"]x = 250
s = "FishC"def say_hello():print("Hello FishC")def say_hi():print("Hi FishC")

此时,s和say_hi不能被访问到

但是如果不是使用from hello import *,而是使用import hello as h,则可以正常访问:

__all__属性也可以应用在包的__init__.py文件中,现在有一个FC包,里面有三个模块:fc1.py,fc2.py,fc3.py,以及一个空的__init__.py文件,在另一个文件中导入该包:

使用dir()函数可以获取当前作用域的变量和方法,结果如下:

可以看到,并未得到fc1,fc2,fc3三个模块,但是如果在__init__.py里使用__all__属性:

 然后在另一个模块中就可以使用fc1和fc2这两个模块了: 

总结:对于模块来说,如果没有使用__all__属性,使用from 模块名 import *的方式导入,将导入模块的所有内容;对于包来说,如果__init__.py没有使用__all__属性,使用from 包名 import *的方式导入,将不会导入包里的任何模块。 

4. 文件操作

打开一个文件:

f = open('FishC.txt', 'w')

此时会创建一个文件FishC.txt,并且可以对这个文件进行写入:

f.write("I love Python")
f.writelines(["I love FishC\n", "I love my wife."])
f.close()

write方法是写入一个字符串,不会换行。writelines写入的是可迭代对象,注意,该方法也不会换行。文件如果操作完毕,需要调用close方法进行关闭。

使用r+的模式打开文件,既可以读,又可以写:

f = open("FishC.txt", "r+")
f.readable() #返回True
f.writable() #返回Truefor item in f:print(f)

此时,如果使用f.read()方法再去读取该文件,会得到空字符串,因为此时f的文件指针已经指到文件末尾了。使用f.tell()可以查看文件指针的位置: 

f.tell()  # 44f.seek(0) # 将文件指针移到指定位置,此时移到文件开头
f.readline()  # 读取一行
f.read()  # 读取到文件结束的位置(EOF)

使用flush方法可以在不关闭文件的情况下,将内容写到文件(计算机磁盘)中。

使用truncate方法将文件截取到指定位置,即之后的内容(包括指定位置)全部丢弃:

f.truncate(29)

如果打开文件的模式是'w',并且该文件存在,那么文件原来内容会被全部清空。

open函数总是需要调用close函数,但是文件操作过程中发生异常,那么可能会导致文件对象没有close。针对这个问题,可以使用with语句(上下文管理器)来解决:

with open("FishC.txt", "w") as f:f.write("I love FishC.")

使用pickle模块的dump方法可以将python对象(包括字符串、列表、字典等)序列化,即转化为二进制格式: 

import picklex, y, z = 1, 2, 3
s = "FishC"
l = ["小甲鱼", 520, 3.14]
d = {"one": 1, "two": 2}with open("data.pkl", "wb") as f:pickle.dump(x, f)pickle.dump(y, f)pickle.dump(z, f)pickle.dump(s, f)pickle.dump(l, f)pickle.dump(d, f)

使用pickle模块的load方法可以将pickle文件反序列化为Python对象,注意读取顺序为序列化时写入的顺序(即先写入的先读出来,后写入的后读出来):

import picklewith open("data.pkl", "rb") as f:x = pickle.load(f)y = pickle.load(f)z = pickle.load(f)s = pickle.load(f)l = pickle.load(f)d = pickle.load(f)print(x, y, z, s, l, d, sep="\n")

 

上述对象有点多,使用元组的方式在写入和读取时打包解包可以简化代码:

import picklex, y, z = 1, 2, 3
s = "FishC"
l = ["小甲鱼", 520, 3.14]
d = {"one": 1, "two": 2}with open("data.pkl", "wb") as f:pickle.dump((x, y, z, s, l, d), f)with open("data.pkl", "rb") as f:x, y, z, s, l, d = pickle.load(f)print(x, y, z, s, l, d, sep="\n")

5. 使用pathlib操作文件路径

pathlib是Python3.4之后才有的包,用于替代os.path。从pathlib中导入Path:

from pathlib import Path

使用cwd方法获取当前路径:

Path是一个类,传入字符串就可以获得一个Path对象:

将Path对象用反斜杠和字符串进行拼接,就可获得一个新的Path对象:

判断Path对象是否为一个文件/文件夹:

判断路径/文件是否存在:

 

通过Path对象的name属性可以获取文件/文件夹的名字,即最后一个反斜杠后面的内容:

通过Path对象的stem属性可以获取文件的文件名(不带后缀):

通过Path对象的suffix属性可以获取文件的后缀:

通过Path对象的parent属性可以获取文件/文件夹的上一级目录:

通过Path对象的parent属性可以获取文件/文件夹的各级目录,以元组的形式存储:

通过Path对象的stat()方法可以获取文件/文件夹的信息,比如stat方法返回的对象中有个属性st_size表示大小(单位为字节):

通过Path对象的resolve()方法可以将相对路径转换为绝对路径:

通过Path对象的iterdir()方法获取当前目录下的所有子文件和子文件夹:

通过Path对象的mkdir()方法创建目录:

如果要创建的目录已存在,调用mkdir方法会报错。如果想要忽略报错,关键字参数exist_ok设为True即可:

如果创建的目录的父目录不存在,也会报错:

如果想要将不存在的父目录也创建,parent参数设置为True即可:

 

通过Path对象的open()方法打开文件,其中可以指定操作模式,比如'w',open方法返回一个文件对象,可以对其进行读写操作:

 

通过Path对象的rename()方法进行重命名:

注意此时只传了一个新文件名字符串,没有传入路径,文件将会被移动到当前工作目录(cwd()方法可以查看当前工作目录)。

通过Path对象的rmdir()方法和unlink()方法删除文件夹和文件:

如果目录不为空,调用rmdir()方法会报错 

 

 通过Path对象的glob()方法来查找文件:

 

6. 将程序发布到PyPI上

将程序发布到PyPI上,将可以让世界上所有的程序员通过pip下载你的代码。具体步骤请参考:模块和包(下)_哔哩哔哩_bilibili

相关文章:

零基础学习Python(六)

1. 元类的应用 使用元类给对象添加一个固有属性author: 对类名进行限定,要求类名必须是大写字母开头: class MetaC(type):def __init__(cls, name, bases, attrs):if not name.istitle():raise TypeError("类名必须是大写字母开头~")return …...

微信小程序--31(todolist案例)

一.功能 输入待办事件添加代办事件删除代办事件 二、步骤 1.添加输入框 .wxml代码&#xff1a; <!-- 1.输入框 --><input type"text" bindinput"handleInput" value"{{text}}" /> .wxss代码&#xff1a; /* 1.输入框样式 */ i…...

springboot项目使用本地依赖项,打包后出现NoClassDefFoundError的一种解决方法

可以把本地依赖项上传到本地仓库后再引用 建立 Maven 本地仓库并将依赖上传到本地仓库 要建立 Maven 本地仓库并将依赖上传到本地仓库&#xff0c;可以按照以下步骤进行操作&#xff1a; 1. 配置 Maven 本地仓库路径 Maven 默认会在用户的主目录下的 .m2/repository 目录创…...

Maven高级使用指南

在开发大型项目时&#xff0c;Maven作为一个强大的构建和项目管理工具&#xff0c;能显著提升项目管理和构建的效率。然而&#xff0c;随着项目的扩大&#xff0c;维护和管理的复杂性也随之增加。本文将探讨一些高级的Maven用法和解决方案&#xff0c;以帮助你更好地管理大型项…...

windows docker 执行apt-get 权限问题

今天在windows下安装的docker 部署的容器执行apt-get遇到权限问题 PS C:\Users\xiaok> docker exec -it jenkins sh $ apt-get update Reading package lists... Done E: Could not open lock file /var/lib/apt/lists/lock - open (13: Permission denied) E: Unable to l…...

Linux系统信息排查

目录 介绍步骤 介绍 1、熟悉查看CPU信息、操作系统信息、用户信息、特殊权限账户、启动项和任务计划的排查命令 2、在进行受害主机排查时&#xff0c;首先要对主机系统进行基本排查&#xff0c;方便对受害主机有一个初步的了解。 3、利用lscpu和uname -a查看系统硬件软件基本…...

《图解设计模式》笔记(四)分开考虑

九、Bridge模式&#xff1a;将类的功能层次结构与实现层次结构分离 类的两个层次结构和作用 类的功能层次结构&#xff1a;希望增加新功能时 父类有基本功能&#xff0c;在子类中增加新功能 Something父类 …├─SomethingGood子类 想要再增加新功能 Something父类 …├─So…...

Linux shell编程学习笔记74:sed命令——沧海横流任我行(中)

0 前言 自 60 年代末以来&#xff0c;sed 一直是 Unix 标准工具箱的一部分。 Sed在以下三种情况下特别有用&#xff1a; 编辑太大的文件&#xff0c;无法进行舒适的交互式编辑&#xff1b; 当编辑命令序列过于复杂而无法在交互模式下轻松键入时&#xff0c;可以编辑任何大小的…...

[数据集][目标检测]道路积水检测数据集VOC+YOLO格式2699张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2699 标注数量(xml文件个数)&#xff1a;2699 标注数量(txt文件个数)&#xff1a;2699 标注…...

不同路径

不同路径 思路&#xff1a; 法一&#xff1a;动态规划 const int N 110; class Solution { int dp[N][N];//dp[i][j]&#xff1a;从起点走到 i j的路径个数。 public:int uniquePaths(int m, int n) {for(int i1;i<n;i){dp[1][i]1;} for(int i1;i<m;i) dp[i][1]1;f…...

【HTML】HTML学习之引入CSS样式表

1、CSS样式规则 选择器{属性1:属性值1; 属性2:属性值2; 属性3:属性值3;}2、HTML引入CSS样式表 2.1、行内式 行内式也称为内联样式&#xff0c;是通过标签的style属性来设置元素的样式&#xff0c;其基本语法格式如下: <标签名 style"属性1:属性值1; 属性2:属性值2;…...

shaushaushau1

CVE-2023-7130 靶标介绍&#xff1a; College Notes Gallery 2.0 允许通过“/notes/login.php”中的参数‘user’进行 SQL 注入。利用这个问题可能会使攻击者有机会破坏应用程序&#xff0c;访问或修改数据. 已经告诉你在哪里存在sql注入了&#xff0c;一般上来应该先目录扫…...

揭秘面试必备:高频算法与面试题全面解析

干货分享&#xff0c;感谢您的阅读&#xff01; &#xff08;暂存篇---后续会删除&#xff0c;完整版和持续更新见高频面试题基本总结回顾&#xff08;含笔试高频算法整理&#xff09;&#xff09; 备注&#xff1a;引用请标注出处&#xff0c;同时存在的问题请在相关博客留言…...

设计模式-visit模式-在语法树的实践

文章目录 背景示例代码分析灵活性双重分派 总结 背景 很多项目代码有accept()用法&#xff0c;在calcite 里也看到了这种&#xff0c;深入了解一下 语法树遍历&#xff1a;编译器通常会将源代码解析成抽象语法树&#xff08;AST&#xff09;。为了实现不同的编译阶段&#xff…...

ZK-Rollups测评

1. 引言 Matter Labs团队和多个高校研究人员一起&#xff0c;发布2024年论文《Analyzing and Benchmarking ZK-Rollups》&#xff0c;开源代码见&#xff1a; https://github.com/StefanosChaliasos/zkrollup-benchmarking&#xff08;Python&#xff09; 其中&#xff1a; …...

redis生产使用场景(一):并行流+二级缓存

本文主要介绍 redis 缓存在线上的使用场景 由于业务的特殊性&#xff0c;在生产库用户表中&#xff0c;大概有 50 多万的测试用户&#xff0c;在真实业务计算中&#xff0c;要把测试用户给筛选掉&#xff0c;所以在计算前&#xff0c;需要把测试用户加载到 redis 缓存中&#x…...

EXCEL跨文件查询,指定条件列,返回满足条件的指定列

EXCEL跨文件查询&#xff0c;指定条件列&#xff0c;返回满足条件的指定列 Private Sub cmd_find_from_workbooks_Click() Dim S_Cols As String, thePath As String, Sor_Col As Integer, sz_Cols As Variant S_Cols T_jieguo_cols.Text sz_Cols Split(S_Cols, ",&quo…...

[数据集][目标检测]流水线物件检测数据集VOC+YOLO格式9255张26类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;9255 标注数量(xml文件个数)&#xff1a;9255 标注数量(txt文件个数)&#xff1a;9255 标注…...

StarRocks 存算分离 Compaction 原理

前言 StarRocks 中每次数据摄入都会生成一个新的数据版本&#xff0c;而查询时需要将所有版本数据进行合并才能获得一个正确的结果&#xff0c;如果历史数据版本太多&#xff0c;那么查询时需要读取的文件数也会很多&#xff0c;造成查询效率低下。因而 StarRocks 存在内部任务…...

搭建ELK日志采集与分析系统

SpringCloud微服务实战——企业级开发框架 &#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…...

云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?

大家好&#xff0c;欢迎来到《云原生核心技术》系列的第七篇&#xff01; 在上一篇&#xff0c;我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在&#xff0c;我们就像一个拥有了一块崭新数字土地的农场主&#xff0c;是时…...

springboot 百货中心供应链管理系统小程序

一、前言 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;百货中心供应链管理系统被用户普遍使用&#xff0c;为方…...

脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)

一、数据处理与分析实战 &#xff08;一&#xff09;实时滤波与参数调整 基础滤波操作 60Hz 工频滤波&#xff1a;勾选界面右侧 “60Hz” 复选框&#xff0c;可有效抑制电网干扰&#xff08;适用于北美地区&#xff0c;欧洲用户可调整为 50Hz&#xff09;。 平滑处理&…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销&#xff0c;平衡网络负载&#xff0c;延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...

逻辑回归:给不确定性划界的分类大师

想象你是一名医生。面对患者的检查报告&#xff08;肿瘤大小、血液指标&#xff09;&#xff0c;你需要做出一个**决定性判断**&#xff1a;恶性还是良性&#xff1f;这种“非黑即白”的抉择&#xff0c;正是**逻辑回归&#xff08;Logistic Regression&#xff09;** 的战场&a…...

3.3.1_1 检错编码(奇偶校验码)

从这节课开始&#xff0c;我们会探讨数据链路层的差错控制功能&#xff0c;差错控制功能的主要目标是要发现并且解决一个帧内部的位错误&#xff0c;我们需要使用特殊的编码技术去发现帧内部的位错误&#xff0c;当我们发现位错误之后&#xff0c;通常来说有两种解决方案。第一…...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

什么是EULA和DPA

文章目录 EULA&#xff08;End User License Agreement&#xff09;DPA&#xff08;Data Protection Agreement&#xff09;一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA&#xff08;End User License Agreement&#xff09; 定义&#xff1a; EULA即…...

拉力测试cuda pytorch 把 4070显卡拉满

import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试&#xff0c;通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小&#xff0c;增大可提高计算复杂度duration: 测试持续时间&#xff08;秒&…...