上述的代码需要优化,多行文本写在一个单元格中
时间: 2024-03-20 15:41:42 浏览: 47
确实,上面的代码将多行文本框中的每一行都写入到了Excel文件中的不同行中。如果需要将多行文本框中的所有内容写入到一个单元格中,可以使用Text控件的get方法获取文本框中的所有内容,并将其写入到Excel文件中的同一单元格中。
下面是优化后的示例代码:
```python
from tkinter import *
from openpyxl import Workbook
# 创建主窗口
root = Tk()
root.title("多行文本框写入Excel文件")
# 创建多行文本框
text_box = Text(root, height=10, width=50)
text_box.pack()
# 创建写入Excel文件的按钮
def write_to_excel():
# 获取多行文本框中的输入信息
input_text = text_box.get("1.0", END)
# 创建一个新的Excel文件
wb = Workbook()
ws = wb.active
# 将输入信息写入Excel文件中
ws.cell(1, 1, input_text)
# 保存Excel文件并关闭窗口
wb.save("output.xlsx")
root.destroy()
button = Button(root, text="写入Excel文件", command=write_to_excel)
button.pack()
# 运行主窗口
root.mainloop()
```
在上述代码中,我们将多行文本框中的所有内容都写入到了Excel文件中的同一单元格中。具体做法是,我们使用Text控件的get方法获取多行文本框中的所有内容,并将其写入到Excel文件中的第一行第一列单元格中。这样,就可以将多行文本框中的所有内容写入到同一个单元格中了。
阅读全文