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)將這段代碼修改寫入下拉輸入框和文本内容時按行寫入
时间: 2024-02-01 13:14:10 浏览: 112
可以将文本框中的内容和下拉输入框中的内容按行写入工作表,代码如下:
```
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=i + 1, column=1, value=line.strip())
# 将下拉输入框中的内容按行写入工作表
for i, value in enumerate(combobox_values):
sheet.cell(row=i + 1, column=2, value=value)
# 保存工作簿
workbook.save(filename)
```
这样,文本框中的每一行都会按行写入工作表的第一列,下拉输入框中的每一行都会按行写入工作表的第二列。
阅读全文