Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/310.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 动态生成pygtk菜单';它基于字典和列表_Python_Dynamic_Menu_Pygtk_Generator - Fatal编程技术网

Python 动态生成pygtk菜单';它基于字典和列表

Python 动态生成pygtk菜单';它基于字典和列表,python,dynamic,menu,pygtk,generator,Python,Dynamic,Menu,Pygtk,Generator,我有一个从xml文件读取的选项列表。列表中有一些信息,如代码名、项目关系、子代码名 我使用以下函数生成包含正确按钮的pygtk框。我的问题是,我必须能够在某些点隐藏/显示这些框(例如self.btn\u box\u web.show()/hide() 如何更好地生成菜单或访问菜单 我首先生成一个服务器安装类型列表,并在其中创建一个包含适当按钮的框 def build_custom_server(self, server_type_dict, component_dict): self.c

我有一个从xml文件读取的选项列表。列表中有一些信息,如代码名、项目关系、子代码名

我使用以下函数生成包含正确按钮的pygtk框。我的问题是,我必须能够在某些点隐藏/显示这些框(例如self.btn\u box\u web.show()/hide()

如何更好地生成菜单或访问菜单

我首先生成一个服务器安装类型列表,并在其中创建一个包含适当按钮的框

def build_custom_server(self, server_type_dict, component_dict):
    self.custom_server_box = gtk.VBox(False, 0)
    self.option_box.pack_start(self.custom_server_box, False)
    self.custom_server_box.set_border_width(10)
    self.custom_server_label = gtk.Label("Customize your server instalation:")
    self.custom_server_box.pack_start(self.custom_server_label, True)

    self.type_box = gtk.HBox(True, 0)
    self.custom_server_box.pack_start(self.type_box, False)
    self.type_label = gtk.Label("Server type:")
    self.type_box.pack_start(self.type_label, True)

    for stype in server_type_dict:
        self.btn_name = "self.btn_" + stype
        self.img_name = "self.img_" + stype
        self.label_name = "self.label_" + stype
        self.box_name = "self.btn_box_" + stype

        vars()[self.btn_name] = gtk.ToggleButton()
        vars()[self.box_name] = gtk.VBox(False, 0)
        vars()[self.img_name] = gtk.Image()
        vars()[self.img_name].set_from_file("art/" + stype + ".png")
        vars()[self.label_name] = gtk.Label(server_type_dict[stype])
        vars()[self.box_name].pack_start(vars()[self.img_name], False)
        vars()[self.box_name].pack_end(vars()[self.label_name], False)
        vars()[self.btn_name].add(vars()[self.box_name])
        self.type_box.pack_start(vars()[self.btn_name], True)
        self.load_type(server_type_dict, component_dict, stype)
然后对于每种类型(类型可以在两个字段中,因为我们有主类别和辅助类别),我生成一个包含组件的单独框

def load_type(self, server_type_dict, component_dict, stype):
    self.up_label_name = "self.label_" + stype
    self.up_box_name = "self.btn_box_" + stype
    vars()[self.up_box_name] = gtk.HBox(False, 0)
    vars()[self.up_label_name] = gtk.Label(server_type_dict[stype])
    vars()[self.up_box_name].pack_start(vars()[self.up_label_name], False)

    self.custom_server_box.pack_start(vars()[self.up_box_name], False)
    for compo in component_dict:
        if component_dict[compo][1] == stype:
            self.btn_name = "self.btn_" + compo
            self.img_name = "self.img_" + compo
            self.label_name = "self.label_" + compo
            self.box_name = "self.btn_box_" + compo

            vars()[self.btn_name] = gtk.ToggleButton()
            vars()[self.box_name] = gtk.VBox(False, 0)
            vars()[self.img_name] = gtk.Image()
            vars()[self.img_name].set_from_file("art/" + compo + ".png")
            vars()[self.label_name] = gtk.Label(component_dict[compo][0])
            vars()[self.box_name].pack_start(vars()[self.img_name], False)
            vars()[self.box_name].pack_end(vars()[self.label_name], False)
            vars()[self.btn_name].add(vars()[self.box_name])
            vars()[self.up_box_name].pack_start(vars()[self.btn_name], True)
        elif component_dict[compo][2] == stype:
            self.btn_name = "self.btn_" + compo
            self.img_name = "self.img_" + compo
            self.label_name = "self.label_" + compo
            self.box_name = "self.btn_box_" + compo

            vars()[self.btn_name] = gtk.ToggleButton()
            vars()[self.box_name] = gtk.VBox(False, 0)
            vars()[self.img_name] = gtk.Image()
            vars()[self.img_name].set_from_file("art/" + compo + ".png")
            vars()[self.label_name] = gtk.Label(component_dict[compo][0])
            vars()[self.box_name].pack_start(vars()[self.img_name], False)
            vars()[self.box_name].pack_end(vars()[self.label_name], False)
            vars()[self.btn_name].add(vars()[self.box_name])
            vars()[self.up_box_name].pack_start(vars()[self.btn_name], True)

我的完整代码可以找到

这是很多代码,所以我不完全确定我是否确切知道您想要做什么。不过,我可以想出一些方法,您可以稍后访问这些动态创建的小部件

一种方法是使用
widget.set_name()
为每个小部件指定一个名称。然后,您可以获取所有子小部件,并在它们上迭代寻找具有该名称的小部件。如果您有很多小部件,这可能会很慢。只保留
dict()可能更容易
object键入了从配置文件中获得的名称,您可以稍后动态访问这些名称。例如:

widgets = {}
for stype in server_type_dict:
    widgets[stype] = {}
    widgets[stype]['btn'] = gtk.ToggleButton()
    widgets[stype]['box'] = gtk.VBox(False, 0)
    widgets[stype]['img'] = gtk.Image()
    ...
    self.type_box.pack_start(widgets[stype]['btn'], True)
    self.load_type(server_type_dict, component_dict, stype)
……等等

稍后,如果您需要“web”服务器类型按钮,只需调用
widgets['web']['btn']