# 创建工作簿和工作表 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 09:05:33 浏览: 38
你可以使用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)
```
这样,每次打开文件后,数据都会从工作表的空白行开始写入。
相关问题
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)將這段代碼修改寫入下拉輸入框和文本内容時按行寫入
可以将文本框中的内容和下拉输入框中的内容按行写入工作表,代码如下:
```
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)
```
这样,文本框中的每一行都会按行写入工作表的第一列,下拉输入框中的每一行都会按行写入工作表的第二列。
workbook = openpyxl.load_workbook('example.xlsx') worksheet = workbook.active active是什么意思
在openpyxl中,`active`是一个属性,表示当前活动的工作表。在你打开一个工作簿后,你可以通过`active`属性来访问该工作簿的活动表格。通常情况下,活动表格是最先打开或者最后保存的表格。你可以使用`worksheet`变量来引用该活动表格,以便对它进行读取或者写入操作。例如,`worksheet['A1'] = "Hello World!"`就是在活动表格的第一个单元格中写入了一个字符串。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)