請你幫我修改這段代碼,我不需要複製到本地路徑,我只需要在指定路徑去讀取然後匯總寫入即可import os import shutil from datetime import date import time #指定目标文件夹路径和本地路径 src_folder = r"Y:\iplas\Robot_Log\SMT" dst_folder = "D:\測試log" start_time = time.time() # 获取今天的日期 today = date.today() # 遍历目标文件夹中的所有文件 for file_name in os.listdir(src_folder): if file_name.endswith('.txt'): file_path = os.path.join(src_folder, file_name) if date.fromtimestamp(os.path.getmtime(file_path)) == today: shutil.copy(file_path, os.path.join(dst_folder, file_name)) # 遍历本地路径中的所有文件 file_contents = [] for file_name in os.listdir(dst_folder): if file_name.endswith('.txt'): # 获取文件名(不带后缀) filename = os.path.splitext(file_name)[0] with open(os.path.join(dst_folder, file_name), 'r', encoding='gbk') as t: # 将文件名和内容用逗号分隔,并写入列表 for line in t: file_contents.append(file_name + ',' + line.strip()) # 将所有文件的内容写入汇总文档中 with open(os.path.join(dst_folder, '汇总文档.txt'), 'w', encoding='gbk') as f: # 将列表中的数据使用换行符连接成字符串,并写入文件 f.write('\n'.join(file_contents)) # 获取程序结束时间,计算程序运行时间 end_time = time.time() run_time = end_time - start_time print(f"程序运行时间:{run_time:.2f} 秒")
时间: 2024-01-27 16:02:57 浏览: 79
好的,根据您的需求,我修改了代码,直接在指定路径下读取文件并汇总写入汇总文档中,不需要复制到本地路径。请参考下面的代码:
```python
import os
from datetime import date
import time
# 指定目标文件夹路径和汇总文档路径
src_folder = r"Y:\iplas\Robot_Log\SMT"
dst_file = r"D:\測試log\汇总文档.txt"
相关问题
請你幫我修改我不需要將源文件複製到本地,只需要匯總即可import os import shutil from datetime import date import time #指定目标文件夹路径和本地路径 src_folder = r"Y:\iplas\Robot_Log\SMT" dst_folder = "D:\測試log" start_time = time.time() # 获取今天的日期 today = date.today() # 遍历目标文件夹中的所有文件 for file_name in os.listdir(src_folder): if file_name.endswith('.txt'): file_path = os.path.join(src_folder, file_name) if date.fromtimestamp(os.path.getmtime(file_path)) == today: shutil.copy(file_path, os.path.join(dst_folder, file_name)) # 遍历本地路径中的所有文件 file_contents = [] for file_name in os.listdir(dst_folder): if file_name.endswith('.txt'): # 获取文件名(不带后缀) filename = os.path.splitext(file_name)[0] with open(os.path.join(dst_folder, file_name), 'r', encoding='gbk') as t: # 将文件名和内容用逗号分隔,并写入列表 for line in t: file_contents.append(file_name + ',' + line.strip()) # 将所有文件的内容写入汇总文档中 with open(os.path.join(dst_folder, '汇总文档.txt'), 'w', encoding='gbk') as f: # 将列表中的数据使用换行符连接成字符串,并写入文件 f.write('\n'.join(file_contents)) # 获取程序结束时间,计算程序运行时间 end_time = time.time() run_time = end_time - start_time print(f"程序运行时间:{run_time:.2f} 秒")
好的,你想要修改的是将源文件复制到本地的部分,并且只需要汇总文档而不需要目标路径中的所有文件,对吗?
如果是这样,可以将以下代码替换原来的代码:
```python
# 遍历目标文件夹中的所有文件
for file_name in os.listdir(src_folder):
if file_name.endswith('.txt'):
file_path = os.path.join(src_folder, file_name)
if date.fromtimestamp(os.path.getmtime(file_path)) == today:
# 读取文件内容
with open(file_path, 'r', encoding='gbk') as f:
content = f.read()
# 将文件名和内容用逗号分隔,并写入列表
file_contents.append(file_name + ',' + content.strip())
# 将所有文件的内容写入汇总文档中
with open(os.path.join(dst_folder, '汇总文档.txt'), 'w', encoding='gbk') as f:
# 将列表中的数据使用换行符连接成字符串,并写入文件
f.write('\n'.join(file_contents))
```
这段代码的作用是:
1. 遍历目标文件夹中的所有 `.txt` 文件
2. 读取文件内容,并将文件名和内容用逗号分隔
3. 将文件名和内容加入列表 `file_contents`
4. 将所有文件的内容写入汇总文档中
这样就可以实现只将文件内容汇总到一个文档中,而不需要复制到本地路径了。
使用PYTHON写一段代码,对指定的"D:\1_ZC专项\0-每日批量清洗数据目录\表格汇总前"文件夹下的所有XLSX表格文件,从表格的第3行开始进行读取,将数据顺序保存到一个新的表格里,命令为日期+地名+数据合并的xlsx文件,保存到"D:\1_ZC专项\0-每日批量清洗数据目录\"文件夹中,随后在该合并后的表格第6列后插入一列空值,在第16行第3行写入内容:”VLOOKUP(O3,Sheet2!A:B,2,FALSE)“并向下填充该列后保存表格
好的,这是实现您要求的Python代码:
```python
import os
import openpyxl
# 获取文件夹路径
folder_path = r'D:\1_ZC专项\0-每日批量清洗数据目录\表格汇总前'
# 新建一个工作簿
merged_wb = openpyxl.Workbook()
merged_ws = merged_wb.active
# 遍历文件夹下的所有xlsx文件
for filename in os.listdir(folder_path):
if filename.endswith('.xlsx'):
# 打开工作簿
wb = openpyxl.load_workbook(os.path.join(folder_path, filename))
ws = wb.active
# 读取数据,从第3行开始
data = []
for row in ws.iter_rows(min_row=3, values_only=True):
data.append(row)
# 获取日期和地名
date = ws.cell(row=1, column=2).value
place = ws.cell(row=2, column=2).value
# 将数据顺序保存到新工作簿中
for row in data:
merged_ws.append([date, place] + list(row))
# 关闭工作簿
wb.close()
# 在第6列后插入一列空值
merged_ws.insert_cols(7)
# 写入公式
merged_ws.cell(row=16, column=3).value = 'VLOOKUP(O3,Sheet2!A:B,2,FALSE)'
merged_ws.column_dimensions['C'].width = 40
for row in range(17, merged_ws.max_row+1):
merged_ws.cell(row=row, column=3).value = 'VLOOKUP(O{},Sheet2!A:B,2,FALSE)'.format(row)
# 保存工作簿
merged_wb.save(os.path.join(r'D:\1_ZC专项\0-每日批量清洗数据目录', '{}{}_数据合并.xlsx'.format(date, place)))
merged_wb.close()
```
需要注意的是,代码中的路径可能需要根据您的实际情况进行修改,特别是最后保存合并后的表格的路径。如果您的电脑中没有安装openpyxl模块,可以在命令行中使用以下命令进行安装:
```bash
pip install openpyxl
```
希望这个代码能够满足您的需求!
阅读全文