2016-12-01 23 views
0

私は、スクリプトが実行されるときに、 "チケットが24時間閉まった"というテキストの隣に表示されるようにSQLクエリから結果を取得しようとしています。
SQLクエリは単一の数値を返します。 私は、self.some_textのStaticTextボックスに表示する番号を取得しようとしています。ここで、ラベルテキストは実行時に番号に変更されます。wxPythonを使用してSQLクエリ結果を表示

例:https://s11.postimg.org/jil0kzfqb/tickets.png 画像にはSQLクエリの番号がありません。 (アドレス、ユニット番号、都市のテキストとボックスは無視してください)

他の人が作成した別のプログラムを実行しているため、このコードの一部が必要ない場合があります。 私はすぐにSQLとPythonを学習しようとしています。かなり初心者です。

これは、これまでの私のコードです:

import wx 
import MySQLdb 

db = MySQLdb.connect(host="xxxxxxxxxxxx",port=xxx,user="xx",passwd="xxxxx",db="xxxx") 

class Data(): 
    def TicketsClosedLast24Hours(self, event): 
     cur = db.cursor() 
     cur.execute("Select COUNT(*) FROM HD_TICKET WHERE HD_STATUS_ID = 12 AND TIME_CLOSED >= NOW() - INTERVAL 1 DAY") 
     row = cur.fetchone() 
     print(row[0]) 
     row = cur.fetchone() 

class MainFrame(wx.Frame): 
    def __init__(self): 
     wx.Frame.__init__(self, None) 

     self.Centre() 
     self.Maximize(True) 

     self.background = wx.Panel(self) 
     self.background.SetBackgroundColour(wx.Colour(98, 125, 152)) 

     self.some_text = wx.StaticText(self.background, wx.ID_ANY, label="", style=wx.ALIGN_CENTER) 
     self.Address = wx.TextCtrl(self.background, -1, "", size=(140, -1)) 
     self.UnitNumber = wx.TextCtrl(self.background, -1, "", size=(140, -1)) 
     self.City = wx.TextCtrl(self.background, -1, "", size=(140, -1)) 

     self.horizontalRow0 = wx.BoxSizer() 
     img1 = wx.Image("logo1.bmp", wx.BITMAP_TYPE_BMP, -1) 
     self.bitmap1 = wx.StaticBitmap(self.background, -1, wx.BitmapFromImage(img1), (55, 0)) 
     self.horizontalRow0.Add(self.bitmap1, wx.Center, border=10) 

     self.VerticalRow1 = wx.BoxSizer(wx.VERTICAL) 
     self.VerticalRow1.Add(wx.StaticText(self.background, -1, "Tickets Closed Last 24 Hours", 
              style=wx.ALIGN_CENTER), flag=wx.ALL, border=5) 
     self.VerticalRow1.Add(wx.StaticText(self.background, -1, "Address:", 
              style=wx.ALIGN_CENTER), flag=wx.ALL, border=9) 
     self.VerticalRow1.Add(wx.StaticText(self.background, -1, "Unit Number:", 
              style=wx.ALIGN_CENTER), flag=wx.ALL, border=9) 
     self.VerticalRow1.Add(wx.StaticText(self.background, -1, "City:", 
              style=wx.ALIGN_CENTER), flag=wx.ALL, border=9) 

     # To add labels - H-1 V-2 
     self.VerticalRow2 = wx.BoxSizer(wx.VERTICAL) 
     self.VerticalRow2.Add(self.some_text, proportion=1, flag=wx.ALL, border=6) 
     self.VerticalRow2.Add(self.Address, proportion=1, flag=wx.ALL, border=6) 
     self.VerticalRow2.Add(self.UnitNumber, proportion=1, flag=wx.ALL, border=6) 
     self.VerticalRow2.Add(self.City, proportion=1, flag=wx.ALL, border=6) 

     # Combine V-1 And V-2 to H1 
     self.horizontalRow1 = wx.BoxSizer() 
     self.horizontalRow1.Add((30, 30), proportion=0, flag=wx.EXPAND, border=0) 
     self.horizontalRow1.Add(self.VerticalRow1, proportion=.5) 
     self.horizontalRow1.Add(self.VerticalRow2, proportion=0) 

     # To add labels - H-3 V-8 
     self.VerticalRow1 = wx.BoxSizer(wx.VERTICAL) 

     # To add labels - H-4 V-9 
     self.horizontalRow4 = wx.BoxSizer() 
     self.horizontalRow4.Add((30, 30), proportion=.5, flag=wx.EXPAND, border=0) 
     self.horizontalRow4.Add((30, 30), proportion=1, flag=wx.EXPAND, border=0) 

     # Adds horizontal Rows to Main Window in Vertical boxes 
     self.verticalBox = wx.BoxSizer(wx.VERTICAL) 
     self.verticalBox.Add(self.horizontalRow0, proportion=0, flag=wx.EXPAND, border=10) 
     self.verticalBox.Add((10, 10), proportion=0, flag=wx.EXPAND, border=10) 
     self.verticalBox.Add(self.horizontalRow1, proportion=0, flag=wx.EXPAND, border=0) 
     self.verticalBox.Add((10, 10), proportion=0, flag=wx.EXPAND, border=10) 
     self.verticalBox.Add(self.horizontalRow4, proportion=0, flag=wx.EXPAND, border=0) 

     self.background.SetSizer(self.verticalBox) 
     self.Show() 

    def someFunction(self): 
     mysql_data = databasemodel.returnData() # query your database to return a string 
     self.some_text.SetLabel(mysql_data) 


if __name__ == '__main__': 
    app = wx.App(redirect=False) 
    window = MainFrame() 
    app.MainLoop() 

任意の助けをいただければ幸いです。

ありがとうございます!

+0

あなたの質問は何ですか? –

+0

私は、スクリプトが実行されたときに、 "チケットが24時間閉まったチケット"の横に表示されるようにSQLクエリから結果を取得しようとしています。 SQLクエリは単一の数値を返します。私は、実行時にラベルテキストを番号に変更するself.some_textのStaticTextボックスに表示する番号を取得しようとしています。 https://s11.postimg.org/jil0kzfqb/tickets.png イメージには、SQLクエリの番号がありません。 (アドレス、ユニット番号、都市のテキストとボックスは無視してください) – Cpollack09

+0

質問を編集することをお勧めします。タイトルが質問の本質を反映しているのが最もよいでしょう。 –

答えて

0

コードは正しく表示されます。私は実際にsomeFunctionと呼んでいるものは見ません。私の推測はそれが問題だということです。あなたはそれを呼び出し、mysql_dataをstdoutに出力して、受け取った結果が期待どおりであることを確認してください。

関連する問題