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 13:01:54 浏览: 92
你可以修改下面这段代码,将文本框中的内容按行写入工作表:
```
# 将文本框中的内容按行写入工作表
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。另外,由于这里只需要按行写入文本框中的内容,所以第二个循环可以省略。
相关问题
class ExcelApp: def __init__(self, master): self.master = master master.title("Excel App")# 创建工具栏 toolbar = tk.Frame(master, height=30) tk.Button(toolbar, text="打开", command=self.open_file).pack(side=tk.LEFT, padx=2, pady=2) tk.Button(toolbar, text="保存", command=self.save_file).pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X)# 创建文本框 text_frame = tk.Frame(self.panel_right) text_frame.pack(side=tk.TOP, fill=tk.BOTH, expand=True) self.textbox = tk.Text(text_frame) self.textbox.pack(side=tk.TOP, fill=tk.BOTH, expand=True)def show_sheet(self, sheet_name): self.textbox.tag_configure("left", justify="left") sheet = self.workbook[sheet_name] rows = sheet.max_row # 清空文本框 self.textbox.delete(1.0, tk.END) # 添加表名并设置居中标签 self.textbox.insert(tk.END, sheet_name + ":\n", "center") # 显示工作表内容,并在相应数据后面添加下拉输入框 for row in sheet.iter_rows(values_only=True): for i, cell in enumerate(row): line = str(cell) + "\t" if i == 0: # 在第一列数据后面添加下拉输入框 combobox = tk.ttk.Combobox(self.textbox, values=["下拉选项1", "下拉选项2", "下拉选项3"]) combobox.pack(side=tk.TOP, padx=10, pady=5) self.textbox.window_create(tk.END, window=combobox) self.textbox.insert(tk.END, line, "left") self.textbox.insert(tk.END, "\n") # 设置居中标签的样式 self.textbox.tag_configure("center", justify="center", font=("Arial", 14, "bold"))根據這個函數在寫一個函數,將這個函數生成文本框中的數據内容和下拉輸入框的内容按列寫入一個excel中,在寫入前要判斷文本框中是否存在内容和下拉輸入框是否有值,如果沒有就提醒
您可以按照以下步骤编写一个函数,将该函数生成的文本框中的数据内容和下拉输入框的内容按列写入一个 Excel 文件中:
1. 导入必要的库:
```python
import openpyxl
```
2. 创建一个新的 Workbook 对象:
```python
workbook = openpyxl.Workbook()
```
3. 选择一个工作表:
```python
sheet = workbook.active
```
4. 获取文本框中的数据内容和下拉输入框的值,并将它们按列写入工作表中:
```python
# 获取文本框中的数据
data = self.textbox.get(1.0, tk.END)
# 获取下拉输入框的值
values = []
for widget in self.textbox.winfo_children():
if isinstance(widget, tk.ttk.Combobox):
value = widget.get()
if value:
values.append(value)
else:
messagebox.showwarning("警告", "请填写下拉输入框!")
return
# 判断文本框中是否存在内容
if not data.strip():
messagebox.showwarning("警告", "文本框中没有内容!")
return
# 将数据按列写入工作表中
rows = data.strip().split("\n")
for i, row in enumerate(rows):
cells = row.split("\t")
for j, cell in enumerate(cells):
sheet.cell(row=i+1, column=j+1, value=cell)
# 如果是第一列,添加下拉输入框的值
if j == 0 and values:
validation = openpyxl.worksheet.datavalidation.DataValidation(type="list", formula1='"' + ','.join(values) + '"')
sheet.add_data_validation(validation)
validation.add(sheet.cell(row=i+1, column=j+1))
```
5. 保存 Excel 文件:
```python
workbook.save("output.xlsx")
```
完整的函数如下:
```python
import openpyxl
def save_to_excel(self):
# 创建一个新的 Workbook 对象
workbook = openpyxl.Workbook()
# 选择一个工作表
sheet = workbook.active
# 获取文本框中的数据
data = self.textbox.get(1.0, tk.END)
# 获取下拉输入框的值
values = []
for widget in self.textbox.winfo_children():
if isinstance(widget, tk.ttk.Combobox):
value = widget.get()
if value:
values.append(value)
else:
messagebox.showwarning("警告", "请填写下拉输入框!")
return
# 判断文本框中是否存在内容
if not data.strip():
messagebox.showwarning("警告", "文本框中没有内容!")
return
# 将数据按列写入工作表中
rows = data.strip().split("\n")
for i, row in enumerate(rows):
cells = row.split("\t")
for j, cell in enumerate(cells):
sheet.cell(row=i+1, column=j+1, value=cell)
# 如果是第一列,添加下拉输入框的值
if j == 0 and values:
validation = openpyxl.worksheet.datavalidation.DataValidation(type="list", formula1='"' + ','.join(values) + '"')
sheet.add_data_validation(validation)
validation.add(sheet.cell(row=i+1, column=j+1))
# 保存 Excel 文件
workbook.save("output.xlsx")
```
lass ExcelApp: def init(self, master): self.master = master master.title("Excel App")# 创建工具栏 toolbar = tk.Frame(master, height=30) tk.Button(toolbar, text="打开", command=self.open_file).pack(side=tk.LEFT, padx=2, pady=2) tk.Button(toolbar, text="保存", command=self.save_file).pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X) def save_file(self): def show_sheet(self, sheet_name): self.textbox.tag_configure("left", justify="left") sheet = self.workbook[sheet_name] rows = sheet.max_row # 清空文本框 self.textbox.delete(1.0, tk.END) # 添加表名并设置居中标签 self.textbox.insert(tk.END, sheet_name + ":\n", "center") # 显示工作表内容,并在相应数据后面添加下拉输入框 for row in sheet.iter_rows(values_only=True): for i, cell in enumerate(row): line = str(cell) + "\t" if i == 0: # 在第一列数据后面添加下拉输入框 combobox = tk.ttk.Combobox(self.textbox, values=["下拉选项1", "下拉选项2", "下拉选项3"]) combobox.pack(side=tk.TOP, padx=10, pady=5) self.textbox.window_create(tk.END, window=combobox) self.textbox.insert(tk.END, line, "left") self.textbox.insert(tk.END, "\n") # 设置居中标签的样式 self.textbox.tag_configure("center", justify="center", font=("Arial", 14, "bold")) 根據這個代碼,在用戶點擊保存按鈕時將文本框中下拉輸入框和數據按列寫入一個excel中
可以在save_file()函数中添加以下代码来实现将文本框中下拉输入框和数据按列写入Excel:
```python
def save_file(self):
# 选择保存文件路径
file_path = filedialog.asksaveasfilename(defaultextension=".xlsx")
if not file_path:
return
# 创建Excel文件并写入数据
workbook = openpyxl.Workbook()
sheet = workbook.active
for line in self.textbox.get("1.0", tk.END).splitlines():
row_data = []
for item in line.split("\t"):
if item.startswith("下拉选项"):
row_data.append(item)
else:
row_data.append(float(item))
sheet.append(row_data)
# 保存Excel文件
workbook.save(file_path)
```
其中,使用tkinter内置的文件对话框让用户选择保存文件的路径,然后创建一个新的Excel文件并获取其默认工作表。接着,遍历文本框中的每一行数据,将每个单元格的值分别添加到一个列表中,如果该单元格是下拉输入框,就直接添加该字符串,否则将其转换为浮点数后再添加。最后,将该列表作为一行数据添加到Excel工作表中,并将Excel文件保存到用户选择的路径中。
阅读全文