質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

リストボックス

ユーザーがリストから1つ以上のアイテムを選択できるようにするGUI要素です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

3064閲覧

tkinterで作成したリストボックスに任意のcsvファイルのカラム名だけを表示させたい。

Syo-PT

総合スコア22

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

リストボックス

ユーザーがリストから1つ以上のアイテムを選択できるようにするGUI要素です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/06/19 15:39

前提・実現したいこと

tkinterを使用して、選択したcsvファイルのカラム名だけを抽出して、リストボックス内に表示をさせたいです。

発生している問題・エラーメッセージ

spyder上ではカラム名がアウトプットされるのですが、GUI上のリストボックスに表示がされません。

該当のソースコード

python

1 2import tkinter as tk 3from tkinter import filedialog 4import pandas as pd 5import os 6 7root=tk.Tk() 8root.title("チョイス") 9 10frame=tk.Frame() 11frame.grid(row=0,sticky="we") 12frame_button=tk.Frame() 13frame_button.grid(row=1,sticky="we") 14 15def btn_click(): 16 type = [("all file","*")] 17 path = os.getcwd () 18 file_path = filedialog.askopenfilename(filetypes = type, initialdir = path) 19 20 df = pd.read_csv(file_path, engine="python") 21 df_columns=df.columns.values 22 print(df_columns) 23 24 list_value=tk.StringVar() 25 list_value.set=df_columns 26 27 listbox=tk.Listbox(frame,height=30,listvariable=list_value,selectmode="single") 28 listbox.pack() 29 30Button=tk.Button(frame_button,text="選択",command=btn_click) 31Button.grid(row=1,column=0) 32 33 34root.mainloop() 35

試したこと

listbox.insertなども試してみましたが、うまくできませんでした。

補足情報(FW/ツールのバージョンなど)

M1mac
anacondaを使用しています。
ご教授いただけましたら幸いです。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

set メソッドに代入ではなく、カラム名のリストを与えて呼び出します。
list_value.set(["a", "b", "c"])

投稿2021/06/20 03:59

teamikl

総合スコア8664

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Syo-PT

2021/06/21 05:42 編集

ご教授ありがとうございます。 ご指摘の通り、リストを与えて呼び出すことができました。 一点お聞きしたいのですが、任意のcsvファイルを選択した後に、そのcsvファイルのカラム名を読み込ませて、リストボックスに表示させることは可能でしょうか? df = pd.read_csv(file_path, engine="python") df_columns=df.columns.values 上記でカラム名を取得して、 list_value=tk.StringVar() list_value.set=df_columns こちらで取得したカラム名を表示させようと考えていました。
teamikl

2021/06/21 06:45

list_value.set(df_columns) で出来なかったという事ですか?? 「set メソッドに代入ではなく」 → .set = ... は間違いなので 「カラム名のリストを与えて呼び出し」→ .set(...) という形に変更する、という意図です。 出来ない場合は、カラム名が正しく得られてない可能性がありますが、 >spyder上ではカラム名がアウトプットされる が意図通りなら、コードは問題ないはずなので、 確認の為に、どのように表示されるかを教えてください。 型が文字列のリストになっているかも確認 CSV のカラム名が A,B,C であれば、期待する出力は ['A', 'B', 'C'] といった感じです。
Syo-PT

2021/06/21 08:25

ご回答ありがとうございます。 私が勘違いしていました。 list_value.set(df_columns) で表示させることができました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問