【Flet】ボタンからExcelファイルを処理する【Python】

2024年12月11日Flet,Python

ボタンからExcelファイルを処理する


Excelファイルの内容をページ内に表示する

概要

  • ボタンをクリックしてファイルの選択ダイアログを表示する
  • 選択したファイルの内容をページ内に表示する

Excelファイルの内容

import flet as ft
import pandas as pd

def main(page: ft.Page):
    # ボタンがクリックされたときに実行される関数
    def pick_file(e):
        file_picker.pick_files(allow_multiple=False, allowed_extensions=['xlsx'])

    # ファイルが選択されたときに実行される関数
    def on_file_picked(e: ft.FilePickerResultEvent):
        if e.files:
            file_path = e.files[0].path
            df = pd.read_excel(file_path)

            # データテーブルの作成
            columns = [ft.DataColumn(ft.Text(col)) for col in df.columns]
            rows = [
                ft.DataRow(cells=[ft.DataCell(ft.Text(str(cell))) for cell in row])
                for row in df.values
            ]

            data_table.columns = columns
            data_table.rows = rows
            page.update()

    file_picker = ft.FilePicker(on_result=on_file_picked)
    page.overlay.append(file_picker)

    # ボタンとデータテーブルを作成
    pick_button = ft.ElevatedButton('ファイルを選択', on_click=pick_file)
    data_table = ft.DataTable()

    # 画面サイズ
    page.window_width = 500
    page.window_height = 500

    # ページにボタンとデータテーブルを追加
    page.add(pick_button, data_table)

# Fletアプリケーションを実行
ft.app(target=main)

ボタンクリック実行結果

Excelファイル選択結果


Excelのアプリケーションからファイルを開く

概要

  • ボタンをクリックしてファイルの選択ダイアログを表示する
  • 選択したファイルをExcelのアプリケーションから開く
import flet as ft
import os
import platform

def main(page: ft.Page):
    # ボタンがクリックされたときに実行される関数
    def pick_file(e):
        file_picker.pick_files(allow_multiple=False, allowed_extensions=['xlsx'])

    # ファイルが選択されたときに実行される関数
    def open_file(e):
        if file_picker.result.files:
            file_path = file_picker.result.files[0].path
            print(f'選択したファイルのパス: {file_path}')

            # 実行環境の判定
            try:
                if platform.system() == 'Windows':
                    os.startfile(file_path)
                elif platform.system() == 'Darwin':  # mac
                    os.system(f'open {file_path}')
                else:  # Linux
                    os.system(f'xdg-open {file_path}')
            except Exception as e:
                print(f'ファイルの読み込み中にエラーが発生しました: {e}')

        else:
            print('ファイルが選択されませんでした')

    # 選択ボタンを作成
    file_picker = ft.FilePicker(on_result=open_file)
    pick_file_button = ft.ElevatedButton('ファイルを選択', on_click=pick_file)

    # 画面サイズ
    page.window_width = 350
    page.window_height = 350

    # ページにボタンを追加
    page.add(file_picker, pick_file_button)

# Fletアプリケーションを実行
ft.app(target=main)

Flet,Python

Posted by junichi