import csvimport os# 源文件夹路径source_folder = "/path/to/source/folder"# 新csv文件夹路径output_folder = "/path/to/output/folder"# 获取源文件夹中的所有csv文件csv_files = [f for f in os.listdir(source_folder) if f.endswith('.csv')]# 创建新的csv文件output_files = []with open(os.path.join(output_folder, "output.csv"), 'w') as output_file: output_files.append(csv.writer(output_file)) for i in range(1, len(csv_files)): output_file_path = os.path.join(output_folder, f"output{i}.csv") with open(output_file_path, 'w') as new_output_file: output_files.append(csv.writer(new_output_file))# 遍历每个csv文件for csv_file in csv_files: with open(os.path.join(source_folder, csv_file), 'r') as f: reader = csv.reader(f) # 遍历每行数据 for i, row in enumerate(reader): # 将第i行写入对应的新csv文件 output_files[i].writerow(row)这串代码显示ValueError: I/O operation on closed file.,怎么修改
时间: 2024-02-21 21:57:25 浏览: 30
这个错误可能是因为你已经关闭了一个文件,然后尝试在关闭的文件上执行 I/O 操作。你可以尝试将 `output_files` 中每个 CSV 文件的写入操作放在 `with` 语句块中,以确保文件在使用后被正确关闭。修改后的代码如下:
```python
import csv
import os
# 源文件夹路径
source_folder = "/path/to/source/folder"
# 新csv文件夹路径
output_folder = "/path/to/output/folder"
# 获取源文件夹中的所有csv文件
csv_files = [f for f in os.listdir(source_folder) if f.endswith('.csv')]
# 创建新的csv文件
output_files = []
with open(os.path.join(output_folder, "output.csv"), 'w') as output_file:
output_files.append(csv.writer(output_file))
for i in range(1, len(csv_files)):
output_file_path = os.path.join(output_folder, f"output{i}.csv")
with open(output_file_path, 'w') as new_output_file:
output_files.append(csv.writer(new_output_file))
# 遍历每个csv文件
for csv_file in csv_files:
with open(os.path.join(source_folder, csv_file), 'r') as f:
reader = csv.reader(f)
# 遍历每行数据
for i, row in enumerate(reader):
# 将第i行写入对应的新csv文件
with open(os.path.join(output_folder, f"output{i}.csv"), 'a') as out_file:
writer = csv.writer(out_file)
writer.writerow(row)
```
在这个修改后的代码中,我们将每个 CSV 文件的写入操作放到了内部的 `with` 语句块中,并使用 `'a'` 模式来打开文件,以确保每次写入操作都在文件末尾追加数据。这样就能避免因为关闭文件而导致的 `ValueError: I/O operation on closed file` 错误。
相关推荐
![exe](https://img-home.csdnimg.cn/images/20210720083343.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
网页内源代码模板如下: <html> <meta http-equiv="Content=-Type" content="text/html; charset=utf-8"> <head> </head> <body>[talkid:138031370]2014年4月20日 03:55:45 , 111222 向 232323 发送 我们已经是好友了,开始聊天吧! () [talkid:138031371]2014年4月20日 04:45:45 , 111222 向 123456 发送 音频 :[<ahref="files/f/f123fsasfsfsjdfrhf_n.m4a"]>音频
() [talkid:138031372]2014年4月20日 04:55:45 , 111222 向 123456 发送 图片 :[<ahref="files/f/f123fsasfsfsjdfrhf_n.jpg"]>图片 () </body> </html> 利用python爬虫,打开C:/Users/test/Desktop/DIDItest文件夹下多个文件夹内的html文件源代码,并爬取源代码中的ID、时间、发送号码、接收号码、信息类型、发送内容,如果发送内容不为文本,则提取文件所在链接地址,并将爬取的内容写入csv中,爬取talkid、时间精确至年月日时分秒、发送号码提取第一个 data-hint"">之间的数字,接收号码提取第二个data-hint"">,信息类型就提取 发送与:之间的文字,如果没有:则定义为文字![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
利用python爬虫,提取C:/Users/test/Desktop/DIDItest文件夹下多个文件内的html文件源代码,并提取源代码中的ID、时间、发送号码、接收号码、发送内容,如果发送内容为音频则提取音频所在位置,反之则保留发送内容,并将爬取的内容写入csv中 网页内源代码如下: <html> <meta http-equiv="Content=-Type" content="text/html; charset=utf-8"> <head> </head> <body>[talkid:138031361]2014年4月20日 03:55:45 , 434343 向 232323 发送 我们已经是好友了,开始聊天吧! () [talkid:138031362]2014年4月20日 04:45:45 , 434343 向 123456 发送 音频 :[<ahref="files/f/f123fsasfsfsjdfrhf_n.m4a"]>音频
() [talkid:138031363]2014年4月20日 04:55:45 , 434343 向 123456 发送 音频 :[<ahref="files/f/f123fsasfsfsjdfrhf_n.jpg"]>图片 () [talkid:138031364]2014年4月20日 05:55:45 , 434343 向 3234221 发送 我们已经是好友了,开始聊天吧! () [talkid:138031365]2014年4月20日 06:55:45 , 434343 向 1359075 发送 我们已经是好友了,开始聊天吧! () </body> </html>![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)