python - 使用kivy和sqlite 3的动态表格显示

标签 python listview sqlite kivy

我正在开发一个 GUI 来管理库存(Python 3.4、Sqlite3 和 Kivy 1.9.1),其想法是能够根据产品的不同特征识别产品,这些特征列在一个数据库。

有没有办法使用 kivy 显示 sqlite 表?我认为 ListView 可能是解决方案,但我真的很难理解如何使用正确的 args_converter 制作 CustomListItem 以获取多个列其中有不同的标签。

最佳答案

是的,您可以为此使用RecycleView
试试这个例子:

import sqlite3 as lite

con = lite.connect('test.db')
cur = con.cursor()

try:
    with con:
        cur.execute("CREATE TABLE Cars(Id INT, Name TEXT, Price INT)")
        cur.execute("INSERT INTO Cars VALUES(1,'Audi',52642)")
        cur.execute("INSERT INTO Cars VALUES(2,'Mercedes',57127)")
        cur.execute("INSERT INTO Cars VALUES(3,'Skoda',9000)")
        cur.execute("INSERT INTO Cars VALUES(4,'Volvo',29000)")
        cur.execute("INSERT INTO Cars VALUES(5,'Bentley',350000)")
        cur.execute("INSERT INTO Cars VALUES(6,'Citroen',21000)")
        cur.execute("INSERT INTO Cars VALUES(7,'Hummer',41400)")
        cur.execute("INSERT INTO Cars VALUES(8,'Volkswagen',21600)")
except:
    pass


from kivy.uix.boxlayout import BoxLayout
from kivy.base import runTouchApp
from kivy.lang import Builder
from kivy.properties import ListProperty


Builder.load_string("""

<MyLayout>:
    Button:
        text: "Get data"
        on_press: root.get_data()
    RecycleView:
        data: [{'text':"Id:{} Brand:{} Km:{}".format(id,name,km)} for id,name,km in root.rows]
        viewclass: "Label"
        RecycleBoxLayout:
            default_size: None, dp(56)
            default_size_hint: 1, None
            size_hint_y: None
            height: self.minimum_height
            orientation: 'vertical'

""")


class MyLayout(BoxLayout):
    rows = ListProperty([("Id","Brand","Price")])
    def get_data(self):
        cur.execute("SELECT * FROM Cars")
        self.rows = cur.fetchall()
        print(self.rows)


runTouchApp(MyLayout())

关于python - 使用kivy和sqlite 3的动态表格显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43711589/

相关文章:

python - Flask-类型错误 : __init__() missing 2 required positional arguments: 'name' and 'user_id'

python - 根据输入值进行计数 - 不同 "variables"?

android - 如何在 Xamarin 小部件中使用自定义行创建 ListView

android - ListView 中的搜索数据 react native

c# - SQLite - 从 SQLite 数据库读取数据的最快方法?

c++ - 将参数传递给 void(*)(void*)

python - 排序后的数据未绘制在正确的数据点中

python - 发布 python 模块的标准模式是什么

ListView Builder 中的 ListView 构建器

django - 反向外键到模板中的 django-fts 可搜索模型