简体   繁体   English

显示Kivy中的Ordereddict列表

[英]Display List of Ordereddict in Kivy

I have a list of Ordereddict as follows 我有一个Ordereddict列表如下

list1= [OrderedDict([('Numbers', '15'), ('FirstName', 'John'), ('SecondName', 'Raul'), ('MiddleName', 'Kyle'), ('Grade', 22)]),
OrderedDict([('Names', 'John'), ('NewFirstName', 'Mark'), ('NewSecondName', 'Sachel'), ('NewThirdName', 'Raul'), ('Grade', 15)]),
OrderedDict([('Numbers', '25'),  ('FirstName', 'Kyle'), ('SecondName', 'Venn'), ('MiddleName', 'Marcus'), ('Grade', 24)]),
OrderedDict([('Names', 'Sachel'), ('NewFirstName', 'Venn'), ('NewSecondName', 'Kyle'), ('NewThirdName', 'John'), ('Grade', 71)])]

There are 8 unique keys and one common key in it, i would like to create a table from it in kivy with the same order, with keys being the header of the table. 它有8个唯一键和一个公共键,我想用kivy以相同的顺序创建一个表,键是表的标题。 My expected output is as below, i am new to kivy ecosystem and i dont see anything like tableview in that, any other views could be used to get this output and how 我的预期输出如下,我是kivy生态系统的新手,我没有看到像tableview这样的东西,任何其他视图都可以用来获得这个输出以及如何

Expected output in kivy 预期的产量在kivy

在此输入图像描述

I took the simpler recycyle view example given in the comment and edited the no of columns to 9 and tried picking the values from Ordereddict and i got the below output, since i am new to kivy i am not sure to pull the values as in expected output 我在评论中给出了更简单的recycyle视图示例,并将列的编号编辑为9并尝试从Ordereddict选择值,我得到了以下输出,因为我是kivy的新手,我不确定是否按预期拉取值产量

问题

Below are .py and .kv files 下面是.py.kv文件

check.py check.py

from kivy.app import App
from kivy.uix.boxlayout import BoxLayout
from kivy.uix.recycleview.views import RecycleDataViewBehavior
from kivy.uix.button import Button
from kivy.properties import BooleanProperty, ListProperty, StringProperty, ObjectProperty
from kivy.uix.recyclegridlayout import RecycleGridLayout
from kivy.uix.behaviors import FocusBehavior
from kivy.uix.recycleview.layout import LayoutSelectionBehavior
from kivy.uix.popup import Popup
from collections import OrderedDict
list1= [OrderedDict([('Numbers', '15'), ('FirstName', 'John'), ('SecondName', 'Raul'), ('MiddleName', 'Kyle'), ('Grade', 22)]),
OrderedDict([('Names', 'John'), ('NewFirstName', 'Mark'), ('NewSecondName', 'Sachel'), ('NewThirdName', 'Raul'), ('Grade', 15)]),
OrderedDict([('Numbers', '25'),  ('FirstName', 'Kyle'), ('SecondName', 'Venn'), ('MiddleName', 'Marcus'), ('Grade', 24)]),
OrderedDict([('Names', 'Sachel'), ('NewFirstName', 'Venn'), ('NewSecondName', 'Kyle'), ('NewThirdName', 'John'), ('Grade', 71)])]

class TextInputPopup(Popup):
    obj = ObjectProperty(None)
    obj_text = StringProperty("")

    def __init__(self, obj, **kwargs):
        super(TextInputPopup, self).__init__(**kwargs)
        self.obj = obj
        self.obj_text = obj.text


class SelectableRecycleGridLayout(FocusBehavior, LayoutSelectionBehavior,
                                  RecycleGridLayout):
    ''' Adds selection and focus behaviour to the view. '''


class SelectableButton(RecycleDataViewBehavior, Button):
    ''' Add selection support to the Button '''
    index = None
    selected = BooleanProperty(False)
    selectable = BooleanProperty(True)

    def refresh_view_attrs(self, rv, index, data):
        ''' Catch and handle the view changes '''
        self.index = index
        return super(SelectableButton, self).refresh_view_attrs(rv, index, data)

    def on_touch_down(self, touch):
        ''' Add selection on touch down '''
        if super(SelectableButton, self).on_touch_down(touch):
            return True
        if self.collide_point(*touch.pos) and self.selectable:
            return self.parent.select_with_touch(self.index, touch)

    def apply_selection(self, rv, index, is_selected):
        ''' Respond to the selection of items in the view. '''
        self.selected = is_selected

    def on_press(self):
        popup = TextInputPopup(self)
        popup.open()

    def update_changes(self, txt):
        self.text = txt


class RV(BoxLayout):

    # data_items = ListProperty(newlist)

    data_items = ListProperty([])
    def __init__(self, **kwargs):
        super(RV, self).__init__(**kwargs)
        self.get_users()

    def get_users(self):            
        # create data_items
        for i in list1:
                self.data_items.append(i.values())


class TestApp(App):
    title = "Kivy RecycleView & SQLite3 Demo"

    def build(self):
        return RV()


if __name__ == "__main__":
    TestApp().run()

test.kv test.kv

#:kivy 1.10.0

<TextInputPopup>:
    title: "Popup"
    size_hint: None, None
    size: 400, 400
    auto_dismiss: False

    BoxLayout:
        orientation: "vertical"
        TextInput:
            id: txtinput
            text: root.obj_text
        Button:
            size_hint: 1, 0.2
            text: "Save Changes"
            on_release:
                root.obj.update_changes(txtinput.text)
                root.dismiss()
        Button:
            size_hint: 1, 0.2
            text: "Cancel Changes"
            on_release: root.dismiss()


<SelectableButton>:
    # Draw a background to indicate selection
    canvas.before:
        Color:
            rgba: (.0, 0.9, .1, .3) if self.selected else (0, 0, 0, 1)
        Rectangle:
            pos: self.pos
            size: self.size

<RV>:
    BoxLayout:
        orientation: "vertical"

        GridLayout:
            size_hint: 1, None
            size_hint_y: None
            height: 25
            cols: 9

            Label:
                text: "Numbers"
            Label:
                text: "FirstName"
            Label:
                text: "SecondName"
            Label:
                text: "MiddleName"
            Label:
                text: "Grade"
            Label:
                text: "Names"
            Label:
                text: "NewFirstName"
            Label:
                text: "NewSecondName"
            Label:
                text: "NewThirdName"


        BoxLayout:
            RecycleView:
                viewclass: 'SelectableButton'
                data: [{'text': str(x)} for x in root.data_items]
                SelectableRecycleGridLayout:
                    cols: 9
                    default_size: None, dp(26)
                    default_size_hint: 1, None
                    size_hint_y: None
                    height: self.minimum_height
                    orientation: 'horizontal'
                    multiselect: True
                    touch_multiselect: True

Question - TableView 问题 - TableView

There are 8 unique keys and one common key in it, i would like to create a table from it in kivy with the same order, with keys being the header of the table. 它有8个唯一键和一个公共键,我想用kivy以相同的顺序创建一个表,键是表的标题。

Solution - Using Kivy RecycleView 解决方案 - 使用Kivy RecycleView

Modify the app to extract the keys and values from the collections.OrderedDict 修改应用程序以从collections.OrderedDict提取键和值

  • Add a class attribute of type ListProperty eg column_headings = ListProperty([]) 添加ListProperty类型的类属性,例如column_headings = ListProperty([])
  • Implement nested for loop to extract keys or column headings 实现嵌套for循环以提取键或列标题
  • Implement nested for loop to extract values 实现嵌套for循环以提取值
  • Override None with empty string 使用空字符串覆盖None

Snippets 片段

class RV(BoxLayout):
    column_headings = ListProperty([])
    data_items = ListProperty([])

    def __init__(self, **kwargs):
        super(RV, self).__init__(**kwargs)
        self.get_users()

    def get_users(self):

        # extract keys or column headings
        for row in list1:
            for key in row.keys():
                if key not in self.column_headings:
                    self.column_headings.append(key)

        # extract values
        values = []
        for row in list1:
            for key in self.column_headings:
                try:
                    values.append(str(row[key]))
                    del row[key]
                except KeyError:
                    values.append(None)

        # replace None with empty string
        self.data_items = ['' if x is None else x for x in values]

Output 产量

结果

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM