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

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

文件操作

文件夹/目录

import os

1、os.path.exists(path) 判断一个文件/目录是否存在,只要存在相匹配的文件或目录就返回True,因此当目录与文件同名时可能报错

2、os.path.isdir(fname) 判断目录是否存在,必须是目录才返回True

3、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) 判断文件是否存在,必须是文件才返回True

5、random.sample(file_list, n) 从file_list中随机选择n个文件--import random

6、copyfile(src_path, dst_path) 将src文件内容复制到dst文件中--from shutil import copyfile

7、copy(src_path, dst_path) 将src文件复制到dst文件夹中--from shutil import copy

8、move(src_path, dst_path) 将src文件剪切到dst文件夹---from shutil import move

9、dst=os.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__()可以用来改变实例的内部成员的值。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

classX(object):

def__init__(self, a, b,range):

self.a=a

self.b=b

self.range=range

def__del__(self, a, b,range):

delself.a

delself.b

delself.range

def__call__(self, a, b):

self.a=a

self.b=b

print('__call__ with ({}, {})'.format(self.a,self.b))

>>> xInstance=X(1,2,3)

>>> xInstance(1,2)

__call__ with (1,2)

>>>delX

一些常用函数

1、enumerate(sequence, [start=0])

为可迭代的序列添加了一个计数器默认从0开始

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

elements=('foo','bar','baz')

>>>foreleminelements:

...printelem

...

foo

bar

baz

>>>forcount, eleminenumerate(elements):

...printcount, elem

...

0foo

1bar

2baz

>>>forcount, eleminenumerate(elements,42):

...printcount, elem

...

42foo

43bar

44baz

2、 'sep'.join(seq)

seq:分隔符,可以为空

seq:要连接的元素序列、字符串、元组、字典

连接字符串数组。将字符串、元组、列表中的元素以指定的分隔符连接生成一个新的字符串。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

#对序列进行操作(分别使用' '与':'作为分隔符)

>>> seq1=['hello','good','boy','doiido']

>>>print(' '.join(seq1))

hello good boy doiido

>>>print(':'.join(seq1))

hello:good:boy:doiido

#对字符串进行操作

>>> seq2="hello good boy doiido"

>>>print(':'.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模块参数说明

1

2

3

4

5

6

7

8

9

10

11

12

13

classtqdm(object):

"""

Decorate an iterable object, returning an iterator which acts exactly

like the original iterable, but prints a dynamically updating

progressbar every time a value is requested.

"""

def__init__(self, iterable=None, desc=None, total=None, leave=False,

file=sys.stderr, ncols=None, mininterval=0.1,

maxinterval=10.0, miniters=None, ascii=None,

disable=False, unit='it', unit_scale=False,

dynamic_ncols=False, smoothing=0.3, nested=False,

bar_format=None, initial=0, gui=False):

  • iterable: 可迭代的对象, 在手动更新时不需要进行设置
  • desc: 字符串, 左边进度条描述文字
  • total: 总的项目数
  • leave: bool值, 迭代完成后是否保留进度条
  • file: 输出指向位置, 默认是终端, 一般不需要设置
  • ncols: 调整进度条宽度, 默认是根据环境自动调节长度, 如果设置为0, 就没有进度条, 只有输出的信息
  • unit: 描述处理项目的文字, 默认是'it', 例如: 100 it/s, 处理照片的话设置为'img' ,则为 100 img/s
  • unit_scale: 自动根据国际标准进行项目处理速度单位的换算, 例如 100000 it/s >> 100k it/s

常用函数使用方法

1.tqdm(iterator)

基于迭代器运行:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

importtime

fromtqdmimporttqdm, trange

#trange(i)是tqdm(range(i))的一种简单写法

foriintrange(100):

time.sleep(0.05)

foriintqdm(range(100), desc='Processing'):

time.sleep(0.05)

dic=['a','b','c','d','e']

pbar=tqdm(dic)

foriinpbar:

pbar.set_description('Processing '+i)

time.sleep(0.2)

100%|██████████|100/100[00:06<00:00,16.04it/s]

Processing:100%|██████████|100/100[00:06<00:00,16.05it/s]

Processing e:100%|██████████|5/5[00:01<00:00,4.69it/s]

手动进行更新:

1

2

3

4

5

6

7

8

9

10

11

12

importtime

fromtqdmimporttqdm

with tqdm(total=200) as pbar:

pbar.set_description('Processing:')

# total表示总的项目, 循环的次数20*10(每次更新数目) = 200(total)

foriinrange(20):

# 进行动作, 这里是过0.1s

time.sleep(0.1)

# 进行进度更新, 这里设置10个

pbar.update(10)

Processing::100%|██████████|200/200[00:02<00:00,91.94it/s]

yacs参数配置库

简介

yacs是作为一个轻量级库创建的,用于定义和管理系统配置,比如那些通常可以在为科学实验设计的软件中找到的配置。这些“配置”通常包括用于训练机器学习模型的超参数或可配置模型超参数(如卷积神经网络的深度)等概念。由于您正在进行科学研究,所以再现性是最重要的,因此您需要一种可靠的方法来序列化实验配置。

使用方法

1、初始化并赋值

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

# my_project/config.py

fromyacs.configimportCfgNode as CN

_C=CN()

_C.SYSTEM=CN()

# Number of GPUS to use in the experiment

_C.SYSTEM.NUM_GPUS=8

# Number of workers for doing things

_C.SYSTEM.NUM_WORKERS=4

_C.TRAIN=CN()

# A very important hyperparameter

_C.TRAIN.HYPERPARAMETER_1=0.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 pattern

return_C.clone()

# Alternatively, provide a way to import the defaults as

# a global singleton:

# cfg = _C # users can `from config import cfg`

2、解析yaml文件

config.yaml

1

2

3

4

5

6

7

8

9

10

11

12

GPUS: (0,1,2,3)

OUTPUT_DIR:'output'

CUDNN:

ENABLED: true

MODEL:

NAME:'yolo'

PRETRAINED:'xx.pth'

EXTRA:

FINAL_CONV_KERNEL:1

STAGE2:

NUM_MODULES:1

config.py

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

importos

fromyacs.configimportCfgNode as CN

classconfig():

def__init__(self):

self.cfg=CN()

self.cfg.GPUS=(0,1,2,3)

self.cfg.OUTPUT_DIR='output'

self.cfg.CUDNN=CN()

self.cfg.CUDNN.ENABLED=True

self.cfg.MODEL=CN()

self.cfg.MODEL.NAME=''

self.cfg.MODEL.PRETRAINED=''

self.cfg.MODEL.EXTRA=CN()

self.cfg.MODEL.EXTRA.FINAL_CONV_KERNEL=0

self.cfg.MODEL.EXTRA.STAGE2=CN()

self.cfg.MODEL.EXTRA.STAGE2.NUM_MODULES=0

defget_cfg(self):

returnself.cfg.clone()

defload(self,config_file):

self.cfg.OUTPUT_DIR=''

self.cfg.defrost()

self.cfg.merge_from_file(config_file)

self.cfg.freeze()

if__name__=='__main__':

cc=config()

cc.load("test.yaml")

print(cc.cfg)

print(cc.get_defalut_cfg())

logging日志库 使用方法

1、将控制台的输出写入文件中

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

importlogging

defsetLog():

log_file='L:/log/console.log'

head='%(asctime)-15s %(message)s'

logging.basicConfig(filename=str(log_file),format=head)

logger=logging.getLogger()

logger.setLevel(logging.INFO)

console=logging.StreamHandler()

logging.getLogger('').addHandler(console)

returnlogger

if__name__=='__main__':

logger=setLog()

logger.info('input message')

到此这篇关于Python常用函数及常用库整理的文章就介绍到这了

http://www.jsqmd.com/news/696191/

相关文章:

  • 用Python复现聚宽上的ETF动量轮动策略:从Slope因子到RSRS择时(附完整代码)
  • 从实验室到菜园子:用SOD、POD、CAT指标,在家也能判断植物是否“亚健康”
  • 从芯片手册到AutoSar代码:手把手拆解STM32系列MCU的片内看门狗(Wdg)驱动开发与集成
  • 告别手动拨码!用STM32的UID实现RS485从机地址自动分配(附完整C代码)
  • 非参数统计方法:原理、应用与实战指南
  • 耐高温输送带源头厂家哪家好?耐高温特氟龙传送带哪家好?2026年特氟龙网格输送带厂家推荐:美澳领衔 - 栗子测评
  • Qwen3-4B-Instruct部署案例:ARM架构服务器(如Mac M2/M3)适配实测
  • 2026速洁金丝绒瓷砖品牌有哪些?速洁金丝绒瓷砖+超平釉防滑瓷砖品牌推荐指南 - 栗子测评
  • Python 定时任务调度器实现
  • 从理论到仿真:揭秘Multistage Doherty功率放大器的高回退效率优化策略
  • 你的软件授权还在用Key文件?试试这个‘硬件锁+离线心跳’双保险方案,防破解更安心
  • 深入NVIC寄存器:手撕HAL_NVIC_EnableIRQ()源码,理解STM32中断使能的底层逻辑
  • 2026中西双语播音培训实力TOP名录:播音主持艺考培训、服表培训、木偶表演培训、礼仪文化培训、音乐剧表演培训选择指南 - 优质品牌商家
  • 杭州皖夏废品回收公司联系方式查询:关于专业废旧物资回收服务的通用指南与行业背景解析 - 品牌推荐
  • 从SolidWorks模型到MoveIt仿真:手把手教你配置自己的第一台机械臂
  • ESWA审稿人视角:从投稿到接收,什么样的稿子更容易被“秒过”?
  • hyperf对接项目接入 Coding DevOps
  • 木菲装饰联系方式查询:一站式家装服务提供商的官方联系途径与选择考量 - 品牌推荐
  • 嵌入式C语言如何“欺骗”大模型推理引擎?——揭秘结构体对齐强制转换、定点数模拟FP16、函数指针表替代虚函数的3层伪装术
  • 在Mac上畅玩iOS游戏:PlayCover终极指南与完整教程
  • GBase 8c数据库普通视图与物化视图介绍(二)
  • 【工业通信】PROFIBUS:从标准协议到现场部署的实战解析
  • 2026液态硅胶开模选型指南:技术与交付双维度解析 - 优质品牌商家
  • Python Traceback解析与调试技巧
  • 【代码】计及电池储能寿命损耗的微电网经济调度
  • 木菲装饰联系方式查询指南:如何通过官方渠道获取家装服务信息与规避选择风险 - 品牌推荐
  • 【Java 23种设计模式深度剖析(附代码示例)】
  • 从Open-Channel到ZNS:手把手解析下一代SSD接口如何让存储栈“减肥”增效
  • Cache:从局部性原理到现代CPU的“速度心脏”
  • 手把手教你用Cesium Shader实现带动态倒影的逼真水面(附完整源码)