用tkinter 实现从文件夹选择文件并显示

如何使用tkinter打开一个excel表格并读取数据,并显示出来?

1、使用filedialog,打开文件夹并选择文件

代码如下:

#选择文件
def openfile():
    sfname = filedialog.askopenfilename(title='选择Excel文件', filetypes=[('Excel', '*.xlsx'), ('All Files', '*')])
    return sfname

2、使用treeview(树状表格)显示出来

代码如下:
def showdata(frame,data):
    # 定义树状图表格函数
    '''
    frame:容器
    data:数据,数据类型为列表

    '''

    nrows = len(data)

    ncols = len(data[0])
    columns = [""]
    for i in range(ncols):
        columns.append(str(i))
    heading = columns

    """
        定义Treeview
        self.Frame2为父容器
        columns为列名集合
        show="headings"表示显示表头
    """
    tree = ttk.Treeview(frame, columns=columns, show="headings")


    # 定义各列列宽及对齐方式
    for item in columns:
        tree.column(item, width=50, anchor="center")

    tree.heading(heading[0], text=heading[0])  #第一列的表头为空

    # 定义表头
    for i in range(1, len(columns)):
        tree.heading(heading[i], text=str(i))



    # 设置表格内容
    i = 0
    for v in data:
        v.insert(0, i + 1)    #第一列的显示内容(序号)
        tree.insert('', i, values=(v))
        i += 1

    # 放置控件,rel*表示使用相对定位,相对于父容器的定位
    # tree.place(relx=0, rely=0, relwidth=1, relheight=1)

    return tree

完整代码如下:

from tkinter import filedialog
import xlrd
import tkinter as tk
from tkinter import ttk

#选择文件
def openfile():
    sfname = filedialog.askopenfilename(title='选择Excel文件', filetypes=[('Excel', '*.xlsx'), ('All Files', '*')])
    return sfname

"输入文件名,返回数据"
def readdata(sfname):
    # 读取表格数据
    book = xlrd.open_workbook(sfname)
    sheet1 = book.sheets()[0]
    nrows = sheet1.nrows
    print('表格总行数', nrows)
    ncols = sheet1.ncols
    print('表格总列数', ncols)

    values = []
    for i in range(nrows):
        row_values = sheet1.row_values(i)
        values.append(row_values)
    return values


def showdata(frame,data):
    # 定义树状图表格函数
    '''
    frame:容器
    data:数据,数据类型为列表

    '''

    nrows = len(data)

    ncols = len(data[0])
    columns = [""]
    for i in range(ncols):
        columns.append(str(i))
    heading = columns

    """
        定义Treeview
        self.Frame2为父容器
        columns为列名集合
        show="headings"表示显示表头
    """
    tree = ttk.Treeview(frame, columns=columns, show="headings")


    # 定义各列列宽及对齐方式
    for item in columns:
        tree.column(item, width=50, anchor="center")

    tree.heading(heading[0], text=heading[0])  #第一列的表头为空

    # 定义表头
    for i in range(1, len(columns)):
        tree.heading(heading[i], text=str(i))



    # 设置表格内容
    i = 0
    for v in data:
        v.insert(0, i + 1)    #第一列的显示内容(序号)
        tree.insert('', i, values=(v))
        i += 1

    # 放置控件,rel*表示使用相对定位,相对于父容器的定位
    # tree.place(relx=0, rely=0, relwidth=1, relheight=1)

    return tree




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


def main():
    global root
    root = tk.Tk()
    root.title("打开文件")
    root.geometry("600x400")
    B1 = tk.Button(root, text="打开文件", command=openshow)
    B1.place(relx=0.03,rely=0.05)
    root.mainloop()



if __name__=='__main__':
    main()




参考文献1(打开文件)
https://www.cnblogs.com/SH170706/p/10443947.html
参考文献2(treeview)
https://www.cnblogs.com/yang-2018/p/11824250.html

  • 5
    点赞
  • 102
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值