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)將這段代碼修改寫入内容時按行寫入
时间: 2023-12-23 20:01:54 浏览: 100
ASP.NET中为TextBox中添加calendar.js示例代码
你可以修改下面这段代码,将文本框中的内容按行写入工作表:
```
# 将文本框中的内容按行写入工作表
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。另外,由于这里只需要按行写入文本框中的内容,所以第二个循环可以省略。
阅读全文