当前位置: 首页 > 面试题库 >

Python中的“ IOError:[Errno 0]错误”错误

逄俊贤
2023-03-14
问题内容

我有一个脚本,应该将某些内容附加到文件中,但是它引发了一个我不理解的错误,并且不确定如何触发该错误。

这是代码:

import re

num_words = "four kiddiewinks|four children|four kids"
words_list = num_words.split('|')

def append_2synonym(words_list, num_words):
    with open('test2 words.txt', 'a+') as f:
        read_f = f.read()
        patt = r'^' + words_list[0] + '\|'
        result = re.search(patt, read_f, re.MULTILINE)
        if result == None:
            f.write("\n" + num_words)
        else:
            print "\nNo match found in '2 words.txt' file"

append_2synonym(words_list, num_words)

这是“ test2 words.txt”文件的内容:

five kiddiewinks|five kids|five children
mobile phone|cell phone|cellular phone
stinky cheese|smelly cheese

这是我得到的完整错误:

Traceback (most recent call last):
  File "D:\Magic Briefcase\My Python Scripts\Spin Scripts\synonyms\testing2.py", line 16, in <module>
    append_2synonym(words_list, num_words)
  File "D:\Magic Briefcase\My Python Scripts\Spin Scripts\synonyms\testing2.py", line 12, in append_2synonym
    f.write("\n" + num_words)
IOError: [Errno 0] Error
[Finished in 0.1s with exit code 1]

问题答案:

引用Python文件操作的答案,在Windows上进行读写之间切换时,必须有一个中间的fflush,fsetpos,fseek或rewind操作。

这是一个可能的解决方法:

import re

num_words = "four kiddiewinks|four children|four kids"
words_list = num_words.split('|')

def append_2synonym(words_list, num_words):
    with open('test2 words.txt', 'a+') as f:
        read_f = f.read()
        patt = r'^' + words_list[0] + '\|'
        result = re.search(patt, read_f, re.MULTILINE)
        if result == None:
            f.seek(0,2) # change is here !!
            f.write("\n" + num_words)
        else:
            print "\nNo match found in '2 words.txt' file"

append_2synonym(words_list, num_words)

在中f.seek(0,2)2from_what参数。甲from_what的值0从文件的开头的措施,1使用当前文件的位置,并2使用该文件作为参考点的端部。from_what可以省略,默认为0,使用文件的开头作为参考点。



 类似资料:
  • 我有一个奇怪的错误,我从来没有见过。我使用Chrome运行了一个RF automation回归测试,过了一段时间,我得到了这个错误,它基本上停止了测试执行,并且没有提供任何测试结果。 我还注意到在文本执行过程中我以前没有看到过的这条新的文本行: 文件“C:\python27\lib\site-packages\robot\running\model.py”,第248行,在run self.visi

  • 问题内容: 我似乎正在收到IOError:当我执行Ajax上传时,请求数据读取错误很多。例如,每5个文件上传一次,就会至少出现3次错误。 其他人似乎也有同样的问题。例如。 Django上传失败,请求数据读取错误 Django文件上传偶尔会失败 其他一些观察: 绝对不是我的互联网连接或浏览器问题。似乎在所有浏览器chrome / FF / opera上都在发生。 我正在lucid上运行Django

  • 问题内容: 我已经来了一段时间,并阅读了许多有关该主题的网站。怀疑我有垃圾造成了这个问题。但是哪里? 当我在python中导入MySQLdb时,这是错误: 我正在尝试64位,所以在这里检查: 已将python的默认版本设置为2.6 尝试删除构建目录和python setup.py clean重命名为Python / 2.5 / site-packages,使其无法尝试提取它。 删除所有内容,并按照

  • 问题内容: 当我尝试运行以下程序时,出现了以上错误。有人可以解释什么是内存错误,以及如何解决此问题?。 该程序将字符串作为输入,并找到所有可能的子字符串,并从中创建一个集(按字典顺序),并应在用户要求的相应索引处打印值,否则应打印“无效” 问题答案: 这一个在这里: 对于大型字符串,这似乎非常低效且昂贵。 做得更好 缓冲区对象保留对原始字符串以及开始和长度属性的引用。这样,不会发生不必要的数据重复

  • 我分享的链接geeksforgeeks ide我写的代码https://ide.geeksforgeeks.org/ 在上面的代码中不断获得EO费罗尔 l=[list(map(int,input())] 视场误差:读取一行时的视场误差

  • 问题内容: 我得到: 当我尝试绘制图像并将其保存到PIL中的jpeg中时。关于如何解决这个问题有什么想法吗?过去,在查看/上传图像时,PIL对我来说效果很好。 问题答案: 它可能仅需要zip解码器来保存jpeg。我想我需要在OS X中按照以下步骤预览jpeg。 这可能意味着您需要: 下载PIL源代码。 下载zlib库。 将PIL源指向zlib库。 构建PIL。