鱼C论坛

 找回密码
 立即注册
查看: 1626|回复: 2

[已解决]不懂就問之入門1

[复制链接]
发表于 2020-10-16 14:09:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
刚开始接触Python,请教以下该怎么实现

窗体中添加一个按钮,一个标签,点击按钮弹出选择文件窗口,选择文件后将文件路径返回到标签中


from tkinter import *
import win32ui

def btnCom():
    dgl=win32ui.CreateFileDialog(1)
    dgl.DoModal()
    return dgl.GetPathName()

frm=Tk()
btn=Button(frm,text="請選擇文件1",command=btnCom())
# ety=Entry(frm,text="Tips").grid(row=0,column=1)
lbl=Label(frm,text=btnCom()).grid(row=0,column=1)
btn.grid(row=0,column=0)

frm.mainloop()
最佳答案
2020-10-16 14:26:42
  1. from tkinter import filedialog
  2. import xlrd
  3. import tkinter as tk
  4. from tkinter import ttk
  5. import windnd


  6. # 选择文件
  7. def openfile():
  8.     # 文件对话框获取路径
  9.     sfname = filedialog.askopenfilename(title='选择Excel文件', filetypes=[('Excel', '*.xlsx'), ('All Files', '*')])
  10.     # 拖拽文件获取路径
  11.     # sfname = txt.get("0.0", "end")
  12.     # sfname = sfname.split('\n')[0]
  13.     print(sfname)
  14.     return sfname


  15. "输入文件名,返回数据"


  16. def readdata(sfname):
  17.     # 读取表格数据
  18.     book = xlrd.open_workbook(sfname)
  19.     sheet1 = book.sheets()[0]
  20.     nrows = sheet1.nrows
  21.     print('表格总行数', nrows)
  22.     ncols = sheet1.ncols
  23.     print('表格总列数', ncols)

  24.     values = []
  25.     for i in range(nrows):
  26.         row_values = sheet1.row_values(i)
  27.         values.append(row_values)
  28.     return values


  29. def showdata(frame, data):
  30.     # 定义树状图表格函数
  31.     '''
  32.     frame:容器
  33.     data:数据,数据类型为列表
  34.     '''
  35.     nrows = len(data)
  36.     ncols = len(data[0])
  37.     columns = [""]
  38.     for i in range(ncols):
  39.         columns.append(str(i))
  40.     heading = columns
  41.     """
  42.         定义Treeview
  43.         self.Frame2为父容器
  44.         columns为列名集合
  45.         show="headings"表示显示表头
  46.     """
  47.     tree = ttk.Treeview(frame, columns=columns, show="headings")
  48.     # 定义各列列宽及对齐方式
  49.     for item in columns:
  50.         tree.column(item, width=50, anchor="center")
  51.     tree.heading(heading[0], text=heading[0])  # 第一列的表头为空
  52.     # 定义表头
  53.     for i in range(1, len(columns)):
  54.         tree.heading(heading[i], text=str(i))
  55.     # 设置表格内容
  56.     i = 0
  57.     for v in data:
  58.         v.insert(0, i + 1)  # 第一列的显示内容(序号)
  59.         tree.insert('', i, values=(v))
  60.         i += 1
  61.     # 放置控件,rel*表示使用相对定位,相对于父容器的定位
  62.     # tree.place(relx=0, rely=0, relwidth=1, relheight=1)
  63.     return tree


  64. # 打开文件并以树状表格形式显示
  65. def openshow():
  66.     global root
  67.     filename = openfile()
  68.     data = readdata(filename)
  69.     tree = showdata(root, data)
  70.     tree.place(relx=0.03, rely=0.2, relheight=0.7, relwidth=0.9)


  71. # 拖拽文件操作
  72. def func(files):
  73.     for i in files:
  74.         txt.insert("end", i.decode("gbk") + '\n')


  75. def main():
  76.     global root, txt
  77.     root = tk.Tk()
  78.     root.title("打开文件")
  79.     root.geometry("600x400")

  80.     B1 = tk.Button(root, text="打开文件", command=openshow)
  81.     B1.place(relx=0.03, rely=0.05)

  82.     txt = tk.Text(root)
  83.     txt.pack(side='bottom')
  84.     windnd.hook_dropfiles(txt.winfo_id(), func)

  85.     root.mainloop()


  86. if __name__ == '__main__':
  87.     main()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-16 14:26:42 | 显示全部楼层    本楼为最佳答案   
  1. from tkinter import filedialog
  2. import xlrd
  3. import tkinter as tk
  4. from tkinter import ttk
  5. import windnd


  6. # 选择文件
  7. def openfile():
  8.     # 文件对话框获取路径
  9.     sfname = filedialog.askopenfilename(title='选择Excel文件', filetypes=[('Excel', '*.xlsx'), ('All Files', '*')])
  10.     # 拖拽文件获取路径
  11.     # sfname = txt.get("0.0", "end")
  12.     # sfname = sfname.split('\n')[0]
  13.     print(sfname)
  14.     return sfname


  15. "输入文件名,返回数据"


  16. def readdata(sfname):
  17.     # 读取表格数据
  18.     book = xlrd.open_workbook(sfname)
  19.     sheet1 = book.sheets()[0]
  20.     nrows = sheet1.nrows
  21.     print('表格总行数', nrows)
  22.     ncols = sheet1.ncols
  23.     print('表格总列数', ncols)

  24.     values = []
  25.     for i in range(nrows):
  26.         row_values = sheet1.row_values(i)
  27.         values.append(row_values)
  28.     return values


  29. def showdata(frame, data):
  30.     # 定义树状图表格函数
  31.     '''
  32.     frame:容器
  33.     data:数据,数据类型为列表
  34.     '''
  35.     nrows = len(data)
  36.     ncols = len(data[0])
  37.     columns = [""]
  38.     for i in range(ncols):
  39.         columns.append(str(i))
  40.     heading = columns
  41.     """
  42.         定义Treeview
  43.         self.Frame2为父容器
  44.         columns为列名集合
  45.         show="headings"表示显示表头
  46.     """
  47.     tree = ttk.Treeview(frame, columns=columns, show="headings")
  48.     # 定义各列列宽及对齐方式
  49.     for item in columns:
  50.         tree.column(item, width=50, anchor="center")
  51.     tree.heading(heading[0], text=heading[0])  # 第一列的表头为空
  52.     # 定义表头
  53.     for i in range(1, len(columns)):
  54.         tree.heading(heading[i], text=str(i))
  55.     # 设置表格内容
  56.     i = 0
  57.     for v in data:
  58.         v.insert(0, i + 1)  # 第一列的显示内容(序号)
  59.         tree.insert('', i, values=(v))
  60.         i += 1
  61.     # 放置控件,rel*表示使用相对定位,相对于父容器的定位
  62.     # tree.place(relx=0, rely=0, relwidth=1, relheight=1)
  63.     return tree


  64. # 打开文件并以树状表格形式显示
  65. def openshow():
  66.     global root
  67.     filename = openfile()
  68.     data = readdata(filename)
  69.     tree = showdata(root, data)
  70.     tree.place(relx=0.03, rely=0.2, relheight=0.7, relwidth=0.9)


  71. # 拖拽文件操作
  72. def func(files):
  73.     for i in files:
  74.         txt.insert("end", i.decode("gbk") + '\n')


  75. def main():
  76.     global root, txt
  77.     root = tk.Tk()
  78.     root.title("打开文件")
  79.     root.geometry("600x400")

  80.     B1 = tk.Button(root, text="打开文件", command=openshow)
  81.     B1.place(relx=0.03, rely=0.05)

  82.     txt = tk.Text(root)
  83.     txt.pack(side='bottom')
  84.     windnd.hook_dropfiles(txt.winfo_id(), func)

  85.     root.mainloop()


  86. if __name__ == '__main__':
  87.     main()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-16 14:27:15 | 显示全部楼层
这是选择文件,并打开的代码,你只要文件路径的话,可以修改下就行了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-28 11:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表