首页 > 编程问答 >以 open('acronyms.txt', 'w') 作为文件: file.write(acronym +'_' + 定义 + '

以 open('acronyms.txt', 'w') 作为文件: file.write(acronym +'_' + 定义 + '

时间:2024-07-28 07:37:15浏览次数:11  
标签:python

这并没有覆盖任何内容可能是什么问题?我尝试查看文件目录的路径,它准确匹配

我尝试覆盖文件中的首字母缩略词,但它没有执行任何操作。检查了代码的每个细节,但问题仍然相同


该代码段的问题在于,它每次运行时都会 追加 到文件,而不是覆盖文件。 'w' 模式下的 open() 函数在文件不存在时创建文件,如果文件存在则 将其截断 。然而,如果在循环中使用该函数而没有关闭或不带 'w' 模式,则每次迭代都会将内容追加到文件末尾,而不是覆盖现有内容。

以下是可以解释该问题的场景:

  1. 第一次运行代码: acronyms.txt 不存在,因此创建该文件,并且首字母缩略词和定义写入该文件。
  2. 第二次运行代码: acronyms.txt 已存在。 open('acronyms.txt', 'w') 打开文件,但由于代码在循环中并且没有关闭或不带 'w' 模式,所以不是覆盖现有内容,而是将新内容 追加 到现有内容中。

要解决此问题,需要确保在每次迭代中 使用 'w' 模式打开文件

以下是一些解决方法:

方法 1:在每次迭代中打开和关闭文件:

for acronym, definition in acronyms.items():
    with open('acronyms.txt', 'w') as file:
        file.write(acronym +'_' + definition + '\n') 

此方法在每次迭代中以写入模式打开文件,写入数据,然后关闭文件。这样可以确保在每次迭代中都覆盖文件内容。

方法 2:在循环外打开文件,在每次迭代中截断:

with open('acronyms.txt', 'w') as file:
    for acronym, definition in acronyms.items():
        file.truncate(0)  # 在每次迭代开始时截断文件
        file.write(acronym +'_' + definition + '\n')

此方法在循环外以写入模式打开文件一次,并在每次迭代中使用 file.truncate(0) 截断文件内容。然后,它将当前首字母缩略词和定义写入文件。

通过实施这些更改之一,应该能够覆盖 acronyms.txt 文件的内容,而不必在每次运行脚本时都追加内容。

标签:python
From: 78802666

相关文章

  • 在 Python 中读取部分 MP3 文件时处理“对于可用位计数来说太大”错误
    我正在尝试读取MP3文件的特定部分,但遇到错误:[src/libmpg123/layer3.c:INT123_do_layer3():1771]error:part2_3_length(1376)toolargeforavailablebitcount(760)可以访问音频文件此处我的环境是使用此Docker映像设置的:pytorc......
  • Python SQLAlchemy 2.0 使用 dataclass_transform 非必需字段类型
    我刚刚在一个新项目上安装了SQLAlchemy2.0,我正在尝试使我的模型尽可能类型安全。通过使用@typing_extensions.dataclass_transform,我已经能够实现我想要实现的大部分目标类型检查,但是当前所有字段都被标记为不需要。例如:@typing_extensions.dataclass_tran......
  • 当读取字节时,Python 将 \n 解释为 0xd0
    换行符被解释为Ð(0xd0)而不是(0x0a),我真的不知道如何解决这个问题。我也不知道从哪里开始。当尝试使用此代码时,它将0x0a读为0xd0。withopen(path,"rb")asroot:b_arr=root.read()+b""print("Processing...")buffer=""b_arr......
  • 在Python 3中获取范围的特定形式
    当获取range(1,100)时,我得到:[1,2,3,4,5...99]我需要像这个范围的zip之类的东西:[50,49,51,48,52,47,53...99]如何获取它?背景:这都是关于比特币谜题66的。首先我做了对过去已知的私钥进行线性回归预测,直到第65题为止。我......
  • Python:如何使用pyaudio或sounddevice等库进行自动录音?
    我想做一个项目,需要满足以下录音要求:程序启动后,会在后台不断检测麦克风的声音,当声音分贝大于一定值时打开录音流级别,当分贝低于一定级别时关闭录音流并保存为wav文件。我知道原理,但我无法使用这些库来实现。我想实现以上结果使用Python实现自动录音以下代......
  • 当我们创建一个在 https 服务器上获取和发送数据的 python 应用程序时,我们应该如何处
    python脚本使用Urllib3,我的服务器是在Node.js上编写的脚本。我担心(并且不清楚)证书:我是否需要将我的python应用程序上的证书另存为变量?例如我这样做了,http=urllib3.PoolManager(cert_reqs="CERT_REQUIRED",ca_certs='client-cert.pem')并且我不知道......
  • 使用 Python 进行 Web 抓取以获取数据 NoneType ERROR
    我正在努力为我的学校项目获取美元和价格。所以我决定为此使用网络抓取,但我有一个问题。当我尝试在服务器上使用我的代码时,它给我NoneType错误。它可以在googlecolab上使用,但我无法在我的电脑或服务器上使用。我该如何解决这个问题?网页抓取代码;defdolar():he......
  • Python 请求 - response.json() 未按预期工作
    我正在尝试从Python的requests模块调用API。在邮递员上,返回的响应标头中的Content-Type是application/json;charset=utf-8,响应json数据是我期望的样子。但是,在python上的API的get方法之后运行response.json()会抛出错误simplejson.errors......
  • Python 中的“样板”代码?
    Google有一个Python教程,他们将样板代码描述为“不幸的”,并提供了以下示例:#!/usr/bin/python#importmodulesusedhere--sysisaverystandardoneimportsys#Gatherourcodeinamain()functiondefmain():print'Hellothere',sys.argv[1]#Command......
  • Python 3.9.1 中的 collections.abc.Callable 是否有 bug?
    Python3.9包含PEP585并弃用typing模块中的许多类型,转而支持collections.abc中的类型,现在它们支持__class_getitem__例如Callable就是这种情况。对我来说,typing.Callable和collections.abc.Ca......