如何解决想要读取文件并使用python写入现有的Excel工作表
[在此处输入图片描述] [1]我有一个文本文件,数据用管道定界符定界,我想将其写入Excel工作表。
我已经创建了一个代码,但是由于输入文件中的数据很大(大约45kb),因此执行该代码大约需要700秒。 有什么方法可以优化它?
谢谢
请找到以下代码:
import csv
from time import process_time
def create_sheet():
wb1 = Workbook()
wb1.create_sheet("A")
wb1.create_sheet("B")
src_sheet = wb1.create_sheet("C")
print(type(src_sheet))
wb1.create_sheet("D")
sheet = wb1['Sheet']
wb1.remove(sheet)
write_Data(src_sheet)
wb1.save('outfile.xlsx')
def write_Data(src_sheet):
csv.register_dialect('myDialect',delimiter='|',quoting=csv.QUOTE_ALL)
data_list = []
with open("C:/Users/atapadar/input_text.txt","r") as csvfile:
reader = csv.reader(csvfile,dialect='myDialect')
count: int = 1
for i in reader:
if count == 1:
i.append("New col")
else:
i.append(i[0] + i[1] + i[3])
count = count + 1
src_sheet.append(i)
t1_start = process_time()
create_sheet()
t1_stop = process_time()
print("Elapsed time during the whole program in seconds:",t1_stop - t1_start)
[1]: https://i.stack.imgur.com/X9iMQ.png
解决方法
通过数据框执行此操作会更简单:
df = pd.read_csv("filename.csv",sep="|")
df['New col'] = int(df['C1']) + int(df['C2']) + int(df['C3'])
df.to_excel("output.xlsx",sheet_name='Sheet_name_1')
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。