Python常用函数及常用库整理笔记

news2026/5/3 18:35:56
文件操作文件夹/目录import os1、os.path.exists(path) 判断一个文件/目录是否存在只要存在相匹配的文件或目录就返回True因此当目录与文件同名时可能报错2、os.path.isdir(fname) 判断目录是否存在必须是目录才返回True3、os.makedirs(path) 多层创建目录4、os.mkdir(path) 创建目录5、os.rmdir(path) 删除目录只能删除空目录6、os.rename(原文件名新文件名) 重命名文件或文件夹注意makedirs与mkdir之间最大的区别是当父目录不存在的时候os.mkdir(path)不会创建os.makedirs(path)则会创建父目录。文件1、os.remove(path) 删除文件2、os.rename(原文件名新文件名) 重命名文件或文件夹3、os.listdir(path) 提取目录下所有文件4、os.path.isfile(fname) 判断文件是否存在必须是文件才返回True5、random.sample(file_list, n) 从file_list中随机选择n个文件--import random6、copyfile(src_path, dst_path) 将src文件内容复制到dst文件中--from shutil import copyfile7、copy(src_path, dst_path) 将src文件复制到dst文件夹中--from shutil import copy8、move(src_path, dst_path) 将src文件剪切到dst文件夹---from shutil import move9、dstos.path.join(path,../for_bitmain/img) 修改文件路径10、str.endswith(suffix[, start[, end]]) 判断字符串是否以指定后缀结尾或指定字符串如果以指定后缀结尾返回True否则返回False。可选参数start与end为检索字符串的开始与结束位置。数据格式链表1、len(list) 长度2、max(list) 最大值3、min(list) 最小值4、del(list)/del(list[i]) 删除链表或某一个元素5、list.append(obj) 插入元素6、list.count(obj) 统计某个元素出现的次数7、list.pop([index -1]) 移除一个元素并返回其值默认是最后一个8、list.sort() 排序9、list.clear() 清除10、list.copy() 复制类特殊函数__init__()等同于类的构造器初始化某个类的一个实例。__del__()等同于类的析构函数析构某个类的一个实例。__call__()使实例能够像函数一样被调用同时不影响实例本身的生命周期__call__()不影响一个实例的构造和析构。但是__call__()可以用来改变实例的内部成员的值。12345678910111213141516171819classX(object):def__init__(self, a, b,range):self.aaself.bbself.rangerangedef__del__(self, a, b,range):delself.adelself.bdelself.rangedef__call__(self, a, b):self.aaself.bbprint(__call__ with {}, {}.format(self.a,self.b)) xInstanceX(1,2,3) xInstance(1,2)__call__ with (1,2)delX一些常用函数1、enumerate(sequence, [start0])为可迭代的序列添加了一个计数器默认从0开始12345678910111213141516171819elements(foo,bar,baz)foreleminelements:...printelem...foobarbazforcount, eleminenumerate(elements):...printcount, elem...0foo1bar2bazforcount, eleminenumerate(elements,42):...printcount, elem...42foo43bar44baz2、 sep.join(seq)seq分隔符可以为空seq要连接的元素序列、字符串、元组、字典连接字符串数组。将字符串、元组、列表中的元素以指定的分隔符连接生成一个新的字符串。12345678910111213141516171819202122#对序列进行操作分别使用 与:作为分隔符 seq1[hello,good,boy,doiido]print( .join(seq1))hello good boy doiidoprint(:.join(seq1))hello:good:boy:doiido#对字符串进行操作 seq2hello good boy doiidoprint(:.join(seq2))h:e:l:l:o: :g:o:o:d: :b:o:y: :d:o:i:i:d:o#对元组进行操作 seq3(hello,good,boy,doiido)print(:.join(seq3))hello:good:boy:doiido#对字典进行操作 seq4{hello:1,good:2,boy:3,doiido:4}print(:.join(seq4))boy:good:doiido:hello常用库tqdm进度条库tqdm模块参数说明12345678910111213classtqdm(object):Decorate an iterable object, returning an iterator which acts exactlylike the original iterable, but prints a dynamically updatingprogressbar every time a value is requested.def__init__(self, iterableNone, descNone, totalNone, leaveFalse,filesys.stderr, ncolsNone, mininterval0.1,maxinterval10.0, minitersNone, asciiNone,disableFalse, unitit, unit_scaleFalse,dynamic_ncolsFalse, smoothing0.3, nestedFalse,bar_formatNone, initial0, guiFalse):iterable: 可迭代的对象, 在手动更新时不需要进行设置desc: 字符串, 左边进度条描述文字total: 总的项目数leave: bool值, 迭代完成后是否保留进度条file: 输出指向位置, 默认是终端, 一般不需要设置ncols: 调整进度条宽度, 默认是根据环境自动调节长度, 如果设置为0, 就没有进度条, 只有输出的信息unit: 描述处理项目的文字, 默认是it, 例如: 100 it/s, 处理照片的话设置为img ,则为 100 img/sunit_scale: 自动根据国际标准进行项目处理速度单位的换算, 例如 100000 it/s 100k it/s常用函数使用方法1.tqdm(iterator)基于迭代器运行123456789101112131415161718importtimefromtqdmimporttqdm, trange#trange(i)是tqdm(range(i))的一种简单写法foriintrange(100):time.sleep(0.05)foriintqdm(range(100), descProcessing):time.sleep(0.05)dic[a,b,c,d,e]pbartqdm(dic)foriinpbar:pbar.set_description(Processing i)time.sleep(0.2)100%|██████████|100/100[00:0600:00,16.04it/s]Processing:100%|██████████|100/100[00:0600:00,16.05it/s]Processing e:100%|██████████|5/5[00:0100:00,4.69it/s]手动进行更新123456789101112importtimefromtqdmimporttqdmwith tqdm(total200) as pbar:pbar.set_description(Processing:)# total表示总的项目, 循环的次数20*10(每次更新数目) 200(total)foriinrange(20):# 进行动作, 这里是过0.1stime.sleep(0.1)# 进行进度更新, 这里设置10个pbar.update(10)Processing::100%|██████████|200/200[00:0200:00,91.94it/s]yacs参数配置库简介yacs是作为一个轻量级库创建的用于定义和管理系统配置比如那些通常可以在为科学实验设计的软件中找到的配置。这些“配置”通常包括用于训练机器学习模型的超参数或可配置模型超参数(如卷积神经网络的深度)等概念。由于您正在进行科学研究所以再现性是最重要的因此您需要一种可靠的方法来序列化实验配置。使用方法1、初始化并赋值12345678910111213141516171819202122232425262728# my_project/config.pyfromyacs.configimportCfgNode as CN_CCN()_C.SYSTEMCN()# Number of GPUS to use in the experiment_C.SYSTEM.NUM_GPUS8# Number of workers for doing things_C.SYSTEM.NUM_WORKERS4_C.TRAINCN()# A very important hyperparameter_C.TRAIN.HYPERPARAMETER_10.1# The all important scales for the stuff_C.TRAIN.SCALES(2,4,8,16)defget_cfg_defaults():Get a yacs CfgNode object with default values for my_project.# Return a clone so that the defaults will not be altered# This is for the local variable use patternreturn_C.clone()# Alternatively, provide a way to import the defaults as# a global singleton:# cfg _C # users can from config import cfg2、解析yaml文件config.yaml123456789101112GPUS: (0,1,2,3)OUTPUT_DIR:outputCUDNN:ENABLED: trueMODEL:NAME:yoloPRETRAINED:xx.pthEXTRA:FINAL_CONV_KERNEL:1STAGE2:NUM_MODULES:1config.py1234567891011121314151617181920212223242526272829303132333435importosfromyacs.configimportCfgNode as CNclassconfig():def__init__(self):self.cfgCN()self.cfg.GPUS(0,1,2,3)self.cfg.OUTPUT_DIRoutputself.cfg.CUDNNCN()self.cfg.CUDNN.ENABLEDTrueself.cfg.MODELCN()self.cfg.MODEL.NAMEself.cfg.MODEL.PRETRAINEDself.cfg.MODEL.EXTRACN()self.cfg.MODEL.EXTRA.FINAL_CONV_KERNEL0self.cfg.MODEL.EXTRA.STAGE2CN()self.cfg.MODEL.EXTRA.STAGE2.NUM_MODULES0defget_cfg(self):returnself.cfg.clone()defload(self,config_file):self.cfg.OUTPUT_DIRself.cfg.defrost()self.cfg.merge_from_file(config_file)self.cfg.freeze()if__name____main__:ccconfig()cc.load(test.yaml)print(cc.cfg)print(cc.get_defalut_cfg())logging日志库 使用方法1、将控制台的输出写入文件中1234567891011121314151617importloggingdefsetLog():log_fileL:/log/console.loghead%(asctime)-15s %(message)slogging.basicConfig(filenamestr(log_file),formathead)loggerlogging.getLogger()logger.setLevel(logging.INFO)consolelogging.StreamHandler()logging.getLogger().addHandler(console)returnloggerif__name____main__:loggersetLog()logger.info(input message)到此这篇关于Python常用函数及常用库整理的文章就介绍到这了

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

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

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

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…