前提・実現したいこと
Pythonのkivyを使ったGUIで、ボタンの数を他のExcelファイルから
読み取ったデータ分作成し、表示したい。
発生している問題・エラーメッセージ
Excelファイルには[A1]=A,[A2]=B,...,[A7]=Gと入力しているため
右から2列目のボタンは縦に7分割されてほしいのですが、Aのみしか表示されません。
該当のソースコード
from kivy.app import App from kivy.uix.boxlayout import BoxLayout from kivy.uix.button import Button import openpyxl as px class MainScreen(BoxLayout): def __init__(self, **kwargs): super().__init__(**kwargs) btn = Button(text="test") self.add_widget(btn) btn2 = Button(text="test2") self.add_widget(btn2) bl = BoxLayout() bl.orientation = "vertical" wb = px.load_workbook('sampletest.xlsx') ws = wb.active name_list = [] for i in range(1, 100): if ws.cell(row = i, column = 1).value == None: break else: name_list.append(ws.cell(row = i, column = 1).value) button_list = [] for j in range(len([name_list])): button_n = Button(text = name_list[j]) button_list.append(button_n) for k in range(len([name_list])): bl.add_widget(button_list[k]) self.add_widget(bl) btn3 = Button(text="test3") self.add_widget(btn3) class MainApp(App): def build(self): MS = MainScreen() return MS if __name__=="__main__": MainApp().run()
試したこと
22行目からのname_list作成後、len(name_list)は7となりますが
29行目からのbutton_list作成後、len(button_list)は1となるため
button_listが上手く作成されてないのではと思い29行目からを
button_list = [] for j in range(len([name_list])): button_n_list = [] button_n = Button(text = name_list[j]) button_n_list.append(button_n) button_list.extend(button_n_list)
に変更してみたりしましたが結果は同じでした。
補足情報(FW/ツールのバージョンなど)
Python = 3.7.3
Kivy = 1.11.1
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/09/21 01:30