4

我目前正在为我的 Linux 桌面开发一个应用程序,它从我的 Garmin Forerunner 运动手表中读取数据,解析格式不那么好的 XML 文件,并将数据写入 MySQL 数据库表。我对 Python 或 GTK 没有过多的经验,所以我使用 Glade GUI 设计器处理的图形内容。这就是问题所在。在写入数据库之前,我想添加一些不是来自手表的数据。我阅读和/或计算单圈数、单圈距离、单圈速度和单圈持续时间。但是,我希望能够查看交互中的每一圈,并将该圈分类为 Speedwork、Easy Run 等。使用组合框。根据我的阅读,列表视图是要走的路。

但是,到目前为止,我看到的所有示例和文档都是从代码构建 Listview(而不是通过 Glade 构建的)。我想循环浏览我的列表(lap [type: int]、duration [type: string]、distance [type: float] 和 pace [type: string] ---注意,我将时间存储为字符串来编写它们到我的数据库中的时间/日期字段),并填充列表视图中的字段(我假设这是正确的方法——如果我错了,请纠正我)以及一个组合框进行分类。然后,我将从列表视图中取出每一行并将其写入数据库。

有没有人知道任何可以帮助的例子,或者有没有人有任何具体的想法?

更新:

我基本上想知道,如果我通过 Glade 在 GUI 上放置一个列表视图或树视图,我将如何将它与以下列打包:LapID (int)、Distance (float)、Duration (String) 和一个组合框,其中我可以选择它是什么类型的圈。这是战斗的第一部分。

一旦我填写了列表,我将如何引用每一行以将其写入数据库表?

4

2 回答 2

3

检查下面的示例是否适合您。它从 glade 文件加载 ui 并使用 sqlite 数据库来存储项目。

脚本:

import gtk
import sqlite3

class  ListViewTestApp:
    def __init__(self):
        builder = gtk.Builder()
        builder.add_from_file('listview_test.glade')
        builder.connect_signals(self)

        self.model = builder.get_object('list_items')
        self.list = builder.get_object('items_view')

        column = gtk.TreeViewColumn('column0', gtk.CellRendererText(), text=0)   
        column.set_clickable(True)   
        column.set_resizable(True)   
        self.list.append_column(column)

        column = gtk.TreeViewColumn('column1', gtk.CellRendererText(), text=0)   
        column.set_clickable(True)   
        column.set_resizable(True)   
        self.list.append_column(column)

        self.create_database()
        self.load_list_items()

        window = builder.get_object('main_window')
        window.show_all()

    def create_database(self):
        self.engine = sqlite3.connect(':memory:')
        self.engine.execute('create table test_table ' + \
            '(id INTEGER NOT NULL PRIMARY KEY, test_field0 VARCHAR(30), test_field1 VARCHAR(30))');
        self.add_new_line('test0', 'test000');
        self.add_new_line('test1', 'test111');

    def load_list_items(self):
        self.model.clear()        
        result = self.engine.execute('select * from test_table');
        for row in result: 
            self.model.append([row[1], row[2]])

    def add_new_line(self, test0, test1):
        query = 'INSERT INTO test_table (test_field0, test_field1) VALUES ("{0}", "{1}")'\
            .format(test0, test1)
        self.engine.execute(query)

    def on_load_button_clicked(self, widget):
        self.load_list_items()

    def on_add_line_button_clicked(self, widget):
        id = len(self.model)
        self.add_new_line('new_item{0}'.format(id), 'new__item{0}'.format(id));
        self.load_list_items()

if __name__ == "__main__":
    ListViewTestApp()
    gtk.main()

林间空地文件(listview_test.glade):

<?xml version="1.0" encoding="UTF-8"?>
<interface>
  <requires lib="gtk+" version="2.16"/>
  <!-- interface-naming-policy project-wide -->
  <object class="GtkListStore" id="list_items">
    <columns>
      <!-- column-name column0 -->
      <column type="gchararray"/>
      <!-- column-name column1 -->
      <column type="gchararray"/>
    </columns>
  </object>
  <object class="GtkWindow" id="main_window">
    <child>
      <object class="GtkFixed" id="fixed1">
        <property name="visible">True</property>
        <child>
          <object class="GtkTreeView" id="items_view">
            <property name="width_request">270</property>
            <property name="height_request">250</property>
            <property name="visible">True</property>
            <property name="can_focus">True</property>
            <property name="model">list_items</property>
          </object>
          <packing>
            <property name="x">200</property>
            <property name="y">20</property>
          </packing>
        </child>
        <child>
          <object class="GtkButton" id="load_button">
            <property name="label" translatable="yes">load</property>
            <property name="width_request">100</property>
            <property name="height_request">40</property>
            <property name="visible">True</property>
            <property name="can_focus">True</property>
            <property name="receives_default">True</property>
            <signal name="clicked" handler="on_load_button_clicked"/>
          </object>
          <packing>
            <property name="x">54</property>
            <property name="y">49</property>
          </packing>
        </child>
        <child>
          <object class="GtkButton" id="add_line_button">
            <property name="label" translatable="yes">add line</property>
            <property name="width_request">100</property>
            <property name="height_request">40</property>
            <property name="visible">True</property>
            <property name="can_focus">True</property>
            <property name="receives_default">True</property>
            <property name="xalign">0.41999998688697815</property>
            <property name="yalign">0.46000000834465027</property>
            <signal name="clicked" handler="on_add_line_button_clicked"/>
          </object>
          <packing>
            <property name="x">54</property>
            <property name="y">113</property>
          </packing>
        </child>
      </object>
    </child>
  </object>
</interface>

希望这会有所帮助,问候

于 2011-02-13T22:34:10.050 回答
0

对于那些注意到 'column0' 和 'column1' 相同的人,只需将其更改text=0text=1如下所示:

column = gtk.TreeViewColumn('column1', gtk.CellRendererText(), text=1)

http://www.pygtk.org/docs/pygtk/class-gtktreeviewcolumn.html#constructor-gtktreeviewcolumn

于 2011-05-04T08:26:42.510 回答