# 创建工作簿和工作表 workbook = openpyxl.Workbook() sheet = workbook.active # 将文本框中的内容按行写入工作表 for i, line in enumerate(text.split("\n")): if line.strip() != "": sheet.cell(row=i + 1, column=1, value=line.strip()) # 将下拉输入框中的内容按行写入工作表 for i, value in enumerate(combobox_values): sheet.cell(row=i + 2, column=2, value=value) # 保存工作簿 workbook.save(filename)將這段代碼修改為每次打開都從數據的空白行開始寫入
时间: 2023-12-10 19:05:33 浏览: 76
你可以使用openpyxl库的worksheet.max_row属性来获取工作表的最后一行,然后从下一行开始写入数据。修改后的代码如下:
```
workbook = openpyxl.load_workbook(filename)
sheet = workbook.active
# 获取工作表的最后一行
last_row = sheet.max_row
# 将文本框中的内容按行写入工作表
for i, line in enumerate(text.split("\n")):
if line.strip() != "":
sheet.cell(row=last_row + i + 1, column=1, value=line.strip())
# 将下拉输入框中的内容按行写入工作表
for i, value in enumerate(combobox_values):
sheet.cell(row=last_row + i + 2, column=2, value=value)
# 保存工作簿
workbook.save(filename)
```
这样,每次打开文件后,数据都会从工作表的空白行开始写入。
相关问题
# 创建工作簿和工作表 workbook = openpyxl.Workbook() sheet = workbook.active # 将文本框中的内容按行写入工作表 for i, line in enumerate(text.split("\n")): if line.strip() != "": sheet.cell(row=i + 1, column=1, value=line.strip()) # 将下拉输入框中的内容按行写入工作表 for i, value in enumerate(combobox_values): sheet.cell(row=i + 2, column=2, value=value) # 保存工作簿 workbook.save(filename)將這段代碼修改為值得的excel,可以存放歷史數據
可以按照以下方式修改代码:
```
import openpyxl
from datetime import datetime
# 打开现有的Excel文件
workbook = openpyxl.load_workbook(filename)
# 获取当前工作表或创建一个新的工作表
if "历史数据" in workbook.sheetnames:
sheet = workbook["历史数据"]
else:
sheet = workbook.create_sheet("历史数据")
# 将文本框中的内容按行写入工作表
for i, line in enumerate(text.split("\n")):
if line.strip() != "":
sheet.cell(row=i + 1, column=1, value=line.strip())
# 将下拉输入框中的内容按行写入工作表
for i, value in enumerate(combobox_values):
sheet.cell(row=i + 2, column=2, value=value)
# 添加时间戳
sheet.cell(row=1, column=3, value="时间")
sheet.cell(row=sheet.max_row + 1, column=3, value=datetime.now())
# 保存工作簿
workbook.save(filename)
```
这样,每次保存数据时都会在工作表的第三列添加当前时间的时间戳,方便查看历史数据。同时,如果Excel文件中已经存在名为“历史数据”的工作表,则会直接使用该工作表,否则会创建一个新的工作表。
def save_file(self): # 获取文本框中的内容 text = self.textbox.get("1.0", tk.END) # 获取下拉输入框中的内容 combobox_values = [] for child in self.textbox.winfo_children(): if isinstance(child, tk.ttk.Combobox): combobox_values.append(child.get()) # 获取当前日期作为文件名 today = datetime.date.today().strftime("%Y%m%d") filename = f"Excel_{today}.xlsx" # 创建工作簿和工作表 workbook = openpyxl.Workbook() sheet = workbook.active # 将文本框中的内容按列写入工作表 for i, line in enumerate(text.split("\n")): if line.strip() != "": sheet.cell(row=1, column=i + 1, value=line.strip()) # 将下拉输入框中的内容按列写入工作表 for i, value in enumerate(combobox_values): sheet.cell(row=2, column=i + 1, value=value) # 保存工作簿 workbook.save(filename)將這段代碼修改寫入内容時按行寫入
你可以修改下面这段代码,将文本框中的内容按行写入工作表:
```
# 将文本框中的内容按行写入工作表
for i, line in enumerate(text.split("\n")):
if line.strip() != "":
sheet.cell(row=i + 1, column=1, value=line.strip())
```
这里使用了 `enumerate` 函数来遍历行号和文本框中的每一行。然后使用 `sheet.cell()` 方法将每行文本写入工作表的对应单元格中。注意,行号从1开始,所以需要在 `i` 的基础上加1。另外,由于这里只需要按行写入文本框中的内容,所以第二个循环可以省略。
阅读全文