IOError:[Errno 22]无效模式(' w')或文件名

时间:2015-01-09 17:53:31

标签: python python-2.7 errno

尝试制作文件时,我收到此错误。它被设计为获取创建的.csv文件并将其放入纯文本文件中。

我希望在使用日期和时间戳运行后创建一个新文件,但我在尝试生成文件时似乎得到了Errno 22。

有什么想法吗?

import csv
import time

f = open(raw_input('Enter file name: '),"r")

saveFile = open ('Bursarcodes_'+time.strftime("%x")+ '_'+time.strftime("%X")+
                 '.txt', 'w+')

csv_f = csv.reader(f)

for row in csv_f:
    saveFile.write( 'insert into bursarcode_lookup(bursarcode, note_id)' +
                    ' values (\'' + row[0] + '\', ' + row[1] + ')\n')

f.close()

saveFile.close()

2 个答案:

答案 0 :(得分:6)

您的文件名中不能包含斜杠(/)和冒号(:,但在Unix中允许),但它们正是strftime在其输出中生成的。

Python试图帮助你,它说:

No such file or directory: 'Bursarcodes_01/09/15_19:59:24.txt'

time.strftime("%x")替换为:

time.strftime("%x").replace('/', '.')

...和time.strftime("%X")与此:

time.strftime("%X").replace(':', '_')

答案 1 :(得分:1)

清理版和扩展版:

import csv
import sys
import time

def make_output_fname():
    # Thanks to @Andrew:
    return time.strftime("Bursarcodes_%x_%X.txt").replace("/", "-").replace(":", "-")

def main(csv_fname=None, outfname=None, *args):
    if not csv_fname:
        # first arg not given - prompt for filename
        csv_fname = raw_input("Enter .csv file name: ")

    if not outfname:
        # second arg not given - use serialized filename
        outfname = make_output_fname()

    with open(csv_fname) as inf, open(outfname, "w") as outf:
        incsv = csv.reader(inf)
        for row in incsv:
            outf.write(
                "insert into bursarcode_lookup(bursarcode, note_id) values ('{0}', '{1}')\n"
                .format(*row)
            )

if __name__=="__main__":
    # pass any command-line arguments to main()
    main(*sys.argv[1:])

您现在也可以从命令行运行它。

请注意,如果csv文件中的任何数据项包含未转义的单引号('),您将获得无效的sql。