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

临时文件tempfile

临时文件tempfile

1.概述

安全地创建具有唯一名称的临时文件,以至于他们不会被那些想破坏或者窃取数据的人猜出是非常有挑战性的。tempfile 模块提供了几个安全地创建系统临时文件的方法。 TemporaryFile() 打开并返回一个未命名的临时文件, NamedTemporaryFile() 打开并返回一个命名临时文件,SpooledTemporaryFile 会在将数据写入磁盘之前将内容保存在内存中,TemporaryDirectory 是一个上下文管理器,它会在上下文关闭的时候移除目录。

2.临时文件TemporaryFile

如果需要临时文件来存储数据,而不需要与其他程序共享这些文件,可以使用TemporaryFile创建临时文件,它创建的文件其他程序是不能找到或打开的,因为这个文件在系统表中根本没有对它的引用。不论通过close还是with语句,关闭文件时都会自动删除这个文件。

2.1.创建临时文件

这个例子展示了采用不同方法创建临时文件的差别,一种做法是使用常规方式构建一个临时文件的文件名称,另一种是使用TemporaryFile函数创建临时文件,它返回的文件没有名称并且with语句结束后自动删除临时文件。

import os
import tempfileprint('Building a filename with PID:')
filename = '/tmp/guess_my_name.{}.txt'.format(os.getpid())
with open(filename, 'w+b') as temp:print('temp:')print('  {!r}'.format(temp))print('temp.name:')print('  {!r}'.format(temp.name))# 自己手动清除临时文件
os.remove(filename)print()
print('TemporaryFile:')
with tempfile.TemporaryFile() as temp:print('temp:')print('  {!r}'.format(temp))print('temp.name:')print('  {!r}'.format(temp.name))# 自动清除文件

运行代码,使用TemporaryFile函数创建临时文件比常规方法要简单,而且文件名不会重复,关闭时自动删除临时文件。

Building a filename with PID:
temp:<_io.BufferedRandom name='/tmp/guess_my_name.60756.txt'>
temp.name:'/tmp/guess_my_name.60756.txt'TemporaryFile:
temp:<_io.BufferedRandom name=3>
temp.name:3

2.2.读写临时文件

1.字节模式读写

TemporaryFile默认使用w+b模块创建文件,方便在所有平台表现一致。允许调用者读写这个文件。
向文件写入内容后,需要执行seek函数,才能从临时文件中读取到内容。

import os
import tempfilewith tempfile.TemporaryFile() as temp:# 写入内容temp.write(b'Some data')# 刷新temp.seek(0)# 读取内容print(temp.read())
b'Some data'

2.文本模式读写

要使用文本模式读写文件内容,TemporaryFile创建临时文件时设置模式为w+t

import tempfilewith tempfile.TemporaryFile(mode='w+t') as f:f.writelines(['first\n', 'second\n'])f.seek(0)for line in f:print(line.rstrip())

运行结果,输出文本类型

first
second

3.命名临时文件NamedTemporaryFile

在某些情况下,命名临时文件很重要。对于跨进程甚至跨主机应用程序来说,应用程序各部分之间最简单的数据传递方式是命名文件。 NamedTemporaryFile() 方法会创建一个文件,但不会取消链接,所以它会保留名称(可以通过 name 属性读取)。

import os
import pathlib
import tempfilewith tempfile.NamedTemporaryFile() as temp:print('temp:')print('  {!r}'.format(temp))print('temp.name:')print('  {!r}'.format(temp.name))f = pathlib.Path(temp.name)# with语句执行完,临时文件自动删除
print('Exists after close:', f.exists())

运行结果

temp:<tempfile._TemporaryFileWrapper object at 0x1047e9600>
temp.name:'/var/folders/2k/c77m3hts5l50dj09vc3mw74r0000gn/T/tmpx37l6m04'
Exists after close: False

4.假脱机文件

临时文件如果保存数据相对较小时,使用 SpooledTemporaryFile 可能效率更高,因为它在内容数量超过阈值之前,使用 io.BytesIO 或者 io.StringIO 将数据保存到内存中。当数据量超过阈值之后,数据将会被写入磁盘保存,与此同时,缓冲池也会被替换为 TemporaryFile()。

import tempfilewith tempfile.SpooledTemporaryFile(max_size=100,mode='w+t',encoding='utf-8') as temp:print('temp: {!r}'.format(temp))for i in range(3):temp.write('This line is repeated over and over.\n')print(temp._rolled, temp._file)

运行结果

temp: <tempfile.SpooledTemporaryFile object at 0x1096dda50>
False <_io.TextIOWrapper encoding='utf-8'>
False <_io.TextIOWrapper encoding='utf-8'>
True <_io.TextIOWrapper name=3 mode='w+t' encoding='utf-8'>

也可以显式调用 rollover() 或者 fileno() 方法将数据写入到磁盘

import tempfilewith tempfile.SpooledTemporaryFile(max_size=1000,mode='w+t',encoding='utf-8') as temp:print('temp: {!r}'.format(temp))for i in range(3):temp.write('This line is repeated over and over.\n')print(temp._rolled, temp._file)print('rolling over')temp.rollover()print(temp._rolled, temp._file)

运行代码,调用rollover()方法在磁盘上创建文件。

temp: <tempfile.SpooledTemporaryFile object at 0x103756a10>
False <_io.TextIOWrapper encoding='utf-8'>
False <_io.TextIOWrapper encoding='utf-8'>
False <_io.TextIOWrapper encoding='utf-8'>
rolling over
True <_io.TextIOWrapper name=3 mode='w+t' encoding='utf-8'>

5.临时目录TemporaryDirectory

当需要几个临时文件的时候,使用 TemporaryDirectory 创建一个临时目录并打开所有文件可能会更方便。

import pathlib
import tempfilewith tempfile.TemporaryDirectory() as directory_name:the_dir = pathlib.Path(directory_name)print(the_dir)a_file = the_dir / 'a_file.txt'a_file.write_text('This file is deleted.')print('Directory exists after?', the_dir.exists())
print('Contents after:', list(the_dir.glob('*')))

运行代码,上下文管理器创建了目录,在上下文块里创建文件。上下文结束后会自动删除临时目录和文件

/var/folders/2k/c77m3hts5l50dj09vc3mw74r0000gn/T/tmpr9uxk9yz
Directory exists after? False
Contents after: []

6.预测名

虽然生成的临时文件名称中包含可预测部分比起严格匿名文件安全性较低,但可以找到该文件并对其进行检查以用于调试。
到目前讲述的所有方法都采用三个参数在一定程度上控制文件名,名称生成规则如下:
prefix前缀和suffix后缀参数与一个随机的字符串结合起来建立文件名,dir参数保持不变,作为新文件的位置。

dir + prefix + random + suffix
import tempfilewith tempfile.NamedTemporaryFile(suffix='_suffix',prefix='prefix_',dir='/tmp') as temp:print('temp:')print('  ', temp)print('temp.name:')print('  ', temp.name)

运行结果

temp:<tempfile._TemporaryFileWrapper object at 0x10cc8fdc0>
temp.name:/tmp/prefix_bg25ttl5_suffix

7.临时文件位置

如果没有显式地使用 dir 参数设置临时文件存放的目录,那么临时文件存放的位置将基于操作系统设置。tempfile 模块提供了两个方法用于在运行时查询这个设置。
gettempdir() 方法返回默认的临时文件存放位置, gettempprefix() 返回新临时文件和目录名称的前缀。
gettempdir() 通过直接查询一个列表用来确定当前进程新创建文件的存放位置。搜索的列表依次是:

  • 环境变量:TMPDIR
  • 环境变量:TEMP
  • 环境变量:TMP
  • 系统备选值。( Windows 上采取 C:\temp, C:\tmp, \temp, 或者 \tmp 中的第一个可用值。其他平台使用 /tmp, /var/tmp, 或者 /usr/tmp 。)
    如果以上都不可用,那么就会使用当前目录。
import tempfileprint('gettempdir():', tempfile.gettempdir())
print('gettempprefix():', tempfile.gettempprefix())

运行结果

gettempdir(): /var/folders/2k/c77m3hts5l50dj09vc3mw74r0000gn/T
gettempprefix(): tmp

如果需要使用一个全局目录存储所有临时文件且不依赖环境变量的程序应该手动设置 tempfile.tempdir ,直接给其赋值即可。

import tempfiletempfile.tempdir = '/I/changed/this/path'
print('gettempdir():', tempfile.gettempdir())

运行结果

gettempdir(): /I/changed/this/path

相关文章:

临时文件tempfile

临时文件tempfile 1.概述 安全地创建具有唯一名称的临时文件&#xff0c;以至于他们不会被那些想破坏或者窃取数据的人猜出是非常有挑战性的。tempfile 模块提供了几个安全地创建系统临时文件的方法。 TemporaryFile() 打开并返回一个未命名的临时文件&#xff0c; NamedTemp…...

vue3封装数值动态递增组件

vue3封装数值动态递增组件前言源码举个例子&#xff1a;前言 1&#xff09;使用技术&#xff1a; vue3.2 Ts 2&#xff09;组件接收参数&#xff1a; 参数类型意义是否可选valuenumber数值大小必填durationnumber递增动画持续时间&#xff08;单位&#xff1a;s&#xff09;…...

JavaWeb_RequestResponse

目录 一、概述 二、Request对象 1.Request继承体系 2.Request获取请求数据 ①获取请求行数据 ②获取请求头数据 ③获取请求体数据 ④获取请求参数 3.Request请求转发 三、Response 1.Response设置响应数据功能 ①响应行 ②响应头 ③响应体 2.请求重定向 3.路径问…...

C语言刷题——“C”

各位CSDN的uu们你们好呀&#xff0c;今天&#xff0c;小雅兰要巩固一下之前学过的知识&#xff0c;那么&#xff0c;最好的复习方式就是刷题啦&#xff0c;现在&#xff0c;我们就进入C语言的世界吧 从最简单的开始噢 完完全全零基础都能看懂 题目来源于牛客网 编程语言初学训…...

【刷题】搜索——BFS:城堡问题(The Castle)

目录题目代码&#xff08;Flood Fill&#xff09;代码&#xff08;并查集&#xff09;题目 题目链接 找出房间个数——>求连通块个数 最大房间——>求最大连通块 直接用flood fill算法 注意题目的输入&#xff0c;例如118211182111821&#xff0c;则代表有西、北、南墙…...

深度学习——torch相关函数用法解析

1. torch.ones() torch.ones(*sizes, outNone) → Tensor函数功能&#xff1a;返回一个全为1 的张量&#xff0c;形状由可变参数sizes定义。 参数: sizes (int…) – 整数序列&#xff0c;定义了输出形状 out (Tensor, optional) – 结果张量 例子&#xff1a; >>> …...

ubuntu 20使用kubeadm安装k8s 1.26

步骤 机器&#xff1a;4核8G&#xff0c;root账号&#xff0c;可访问互联网 1、更新apt apt-get update 2、安装一些基本工具 apt-get install ca-certificates curl gnupg lsb-release net-tools apt-transport-https 3、ifconfig 获取ip&#xff0c;hostname获取主机名&…...

低代码开发平台|制造管理-生产过程管理搭建指南

1、简介1.1、案例简介本文将介绍&#xff0c;如何搭建制造管理-生产过程。1.2、应用场景先填充工序信息&#xff0c;再设置工艺路线对应的工序&#xff1b;工序信息及工艺路线列表报表展示的是所有工序、工艺路线信息&#xff0c;可进行新增对应数据的操作。2、设置方法2.1、表…...

python对多个csv文件进行合并(表头需一致)

之前写过python对【多个Excel文件】中的【单个sheet】进行合并&#xff0c;参考&#xff1a;点我 之前也写过python对【多个Excel文件】中的【多个sheet】进行合并&#xff0c;参考&#xff1a;点我 今天再写一个python对多个csv格式的文件进行合并的小工具 但是大家切记&am…...

Salesforce Apex调用邮件模板

正常调用无模板&#xff1a;mail.setToAddresses(new List<String>{user.Email});//mail.setReplyTo(444298824qq.com);//mail.setCcAddresses(null);mail.setSenderDisplayName(EOP系统);mail.setSubject(EOP通知&#xff08;待审批&#xff09;&#xff1a;您有未处理的…...

windows本地开发Spark[不开虚拟机]

1. windows本地安装hadoop hadoop 官网下载 hadoop2.9.1版本 1.1 解压缩至C:\XX\XX\hadoop-2.9.1 1.2 下载动态链接库和工具库 1.3 将文件winutils.exe放在目录C:\XX\XX\hadoop-2.9.1\bin下 1.4 将文件hadoop.dll放在目录C:\XX\XX\hadoop-2.9.1\bin下 1.5 将文件hadoop.dl…...

一文教你快速估计个股交易成本

交易本身对市场会产生影响&#xff0c;尤其是短时间内大量交易&#xff0c;会影响金融资产的价格。一个订单到来时的市场价格和订单的执行价格通常会有差异&#xff0c;这个差异通常被称为交易成本。在量化交易的策略回测部分&#xff0c;不考虑交易成本或者交易成本估计不合理…...

Leetcode—移除元素、删除有序数组中的重复项、合并两个有序数组

移除元素 此题简单&#xff0c;用双指针方法即可&#xff0c; 如果右指针指向的元素不等于val&#xff0c;它一定是输出数组的一个元素&#xff0c;我们就将右指针指向的元素复制到左指针位置&#xff0c;然后将左右指针同时右移&#xff1b; 如果右指针指向的元素等于 val&…...

面试(十)大疆 安全开发 C++1面

1. 在C++开发中定义一个变量,若不做初始化直接使用会怎样? 如果该变量是一个普通变量,则如果对其进行访问,会返回一个随机值,int类型不一定为0,bool类型也不一定为false 如果该变量为一个静态变量,则初始值都是一个0; 如果该变量是一个指针,那么在后续程序运行中很…...

短信链接跳转微信小程序

短信链接跳转微信小程序1 实现方案1.1 通过URL Scheme实现1.2 通过URL Link实现1.3 通过云开发静态网站实现2 实现方案对比3 实践 URL Schema 方案3.1 获取微信access_token3.2 获取openlink3.3 H5页面&#xff08;模拟短信跳转&#xff0c;验证ok&#xff09;4 问题小节4.1 io…...

吉林电视台启用乾元通多卡聚合系统广电视频传输解决方案

随着广播电视数字化、IP化、智能化的逐步深入&#xff0c;吉林电视台对技术改造、数字设备升级提出了更高要求&#xff0c;通过对系统性能、设计理念的综合评估&#xff0c;正式启用乾元通多卡聚合系统广电视频传输解决方案&#xff0c;将用于大型集会、大型演出、基层直播活动…...

Linux常用命令1

目录1、远程登陆服务器2、文件相关&#xff08;1&#xff09;文件和目录属性&#xff08;2&#xff09;创建目录mkdir&#xff08;3&#xff09;删除目录rmdir&#xff08;4&#xff09;创建文件touch&#xff08;5&#xff09;删除文件或目录rm&#xff08;6&#xff09;ls命令…...

【C++进阶】一、继承(总)

目录 一、继承的概念及定义 1.1 继承概念 1.2 继承定义 1.3 继承基类成员访问方式的变化 二、基类和派生类对象赋值转换 三、继承中的作用域 四、派生类的默认成员函数 五、继承与友元 六、继承与静态成员 七、菱形继承及菱形虚拟继承 7.1 继承的分类 7.2 菱形虚拟…...

AttributeError: module ‘lib‘ has no attribute ‘OpenSSL_add_all_algorithms

pip安装crackmapexec后,运行crackmapexec 遇到报错 AttributeError: module lib has no attribute OpenSSL_add_all_algorithms 直接安装 pip3 install crackmapexec 解决 通过 python3 -m pip install --upgrade openssl 或者 python3 -m pip install openssl>22.1.…...

Python实现视频自动打码功能,避免看到羞羞的画面

前言 嗨呀嗨呀&#xff0c;最近重温了一档综艺节目 至于叫什么 这里就不细说了 老是看着看着就会看到一堆马赛克&#xff0c;由于太好奇了就找了一下原因&#xff0c;结果是因为某艺人塌房了…虽然但是 看综艺的时候满影响美观的 咳咳&#xff0c;这里我可不是来教你们如何解…...

Display Driver Uninstaller:Windows显卡驱动终极清理方案

Display Driver Uninstaller&#xff1a;Windows显卡驱动终极清理方案 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-uninstal…...

2026最新版|音频格式转换超详细全攻略:8种方法和避坑指南

你是否有过这样的经历——从录音笔导出的WAV文件体积太大无法发送&#xff0c;下载的FLAC无损音乐在车上无法播放&#xff0c;或者视频剪辑时发现音频格式不被软件识别&#xff1f;这些场景都会用到音频格式转换。本文基于2026年最新可用工具&#xff0c;把8种转换方法极度细化…...

汽车电子架构演进:从分布式ECU到域控制器的技术变革与工程实践

1. 从一周新闻看汽车电子的演进脉络2012年8月的那一周&#xff0c;对于汽车电子行业来说&#xff0c;是平静水面下暗流涌动的一个缩影。当时&#xff0c;我正和几位在主机厂和Tier 1供应商工作的朋友频繁交流&#xff0c;大家普遍的感觉是&#xff0c;传统的汽车电子电气架构&a…...

c++11(一)列表初始化,右值引用和移动语义

一、C11 c11是c发展以来的第二个主要版本&#xff0c;是从c98开始的最重要的更新。之前的博客接触到的都是c98最开始的版本所涉及的内容&#xff0c;接下来会讲解C11里面用的最多也是最重要的语法。 在这里插入图片描述 二、列表初始化 1. c98和c11里的{} C98里传统的{}一般…...

2026年测试工程师常用性能测试平台:高效办公与场景适配指南

测试工程师作为性能测试的核心执行者&#xff0c;对性能平台的需求聚焦于高效办公、功能全面、易用性强、问题定位精准四大维度。测试工程师日常工作涵盖脚本开发、场景编排、压测执行、监控分析、报告生成等多个环节&#xff0c;合适的性能平台&#xff0c;能够提升工作效率&a…...

nlpcda高级配置:如何自定义词典和扩展同义词表

nlpcda高级配置&#xff1a;如何自定义词典和扩展同义词表 【免费下载链接】nlpcda 一键中文数据增强包 &#xff1b; NLP数据增强、bert数据增强、EDA&#xff1a;pip install nlpcda 项目地址: https://gitcode.com/gh_mirrors/nl/nlpcda nlpcda是一款强大的中文数据增…...

模拟内存计算与ReRAM在触觉手势识别中的应用

1. 模拟内存计算技术概述模拟内存计算&#xff08;Analog In-Memory Computing&#xff0c;简称AiMC&#xff09;正在彻底改变传统计算架构的设计范式。这项技术的核心突破在于打破了困扰计算领域长达半个多世纪的"冯诺依曼瓶颈"——即处理器与存储器之间的数据搬运带…...

Windows XP图标主题:如何在现代Linux桌面重现经典视觉体验

Windows XP图标主题&#xff1a;如何在现代Linux桌面重现经典视觉体验 【免费下载链接】Windows-XP Remake of classic YlmfOS theme with some mods for icons to scale right 项目地址: https://gitcode.com/gh_mirrors/win/Windows-XP 还在为现代桌面环境的单调图标感…...

EDA工具进化:从仿真瓶颈到静态分析,构建芯片验证分层防御体系

1. 从“工具崩溃”到“分钟级分析”&#xff1a;EDA工具的十五年进化之路十五年前&#xff0c;当Vinod Menon站在EDA联盟设计奖的领奖台上&#xff0c;手握五千美元支票&#xff0c;他的团队刚刚凭借SwitchIT F12M多端口以太网控制器赢得了业界认可。然而&#xff0c;这位AMD的…...

别再乱用工作队列了!深入Linux内核workqueue的5个特性与3个常见使用误区

深入Linux内核workqueue&#xff1a;5个核心特性与3个高频避坑指南 在Linux内核开发中&#xff0c;工作队列&#xff08;workqueue&#xff09;作为异步任务处理的核心机制&#xff0c;其设计哲学远比表面看到的API调用复杂得多。许多开发者虽然能够熟练使用schedule_work()等基…...