我的程序正在写入.csv文件:
1. Open excel file
2. Copy graph in sheet
3. Paste into a word document
然后我要在同一文件上使用pd.read_csv:
try :
out1 = open(chemin1, 'w')
Logger.info('file opened')
except IOError :
Logger.warning('IOError')
但发生错误:
df=pd.read_csv(chemin1, sep=';', decimal=',')
但是,如果我在使用 File "parser.pyx", line 485, in pandas.parser.TextReader.__cinit__ (pandas/parser.c:4628)
File "parser.pyx", line 607, in pandas.parser.TextReader._get_header (pandas/parser.c:6091)
pandas.parser.CParserError: Passed header=0 but only 0 lines in file
之前关闭文件,则文件可以正常工作。
所以我应该关闭文件,调用pd.read_csv()
然后重新打开文件,还是有一个更优雅的解决方案?
答案 0 :(得分:0)
out1 = open(chemin1, 'w')
,操作系统将锁定 chemin1到磁盘中,并阻止其他人读取或写入内容,直到完成写入和 close 文件为止。否则会有冲突。仅仅想象一下,两个彼此不认识的人同时在同一文件中写东西,文件的内容就会混乱。
并且允许许多进程同时读取文件,例如,许多人阅读同一本书,他们获得相同的内容。