2016-12-01 107 views
0

我試圖從SQL查詢中獲得結果,以便在腳本執行時顯示在文本「Tickets Closed Last 24 Hours」旁邊。
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

我試圖從SQL查詢中獲得結果,以便在腳本執行時顯示在文本「Tickets Closed Last 24 Hours」旁邊。 SQL查詢返回一個單一的數字。我試圖讓數字在StaticText框中顯示self.some_text,它將標籤文本更改爲運行時的數字。 https://s11.postimg.org/jil0kzfqb/tickets.png 在圖像中沒有來自SQL查詢的編號。 (您可以忽略地址,單位編號和城市文字和框) – Cpollack09

+0

我建議您編輯問題,以便讓大家更清楚地知道您究竟在問什麼。如果標題也將反映問題的本質,那將是最好的。 –

回答

0

該代碼看起來對我來說是正確的。雖然我沒有看到任何實際上叫someFunction的東西。我的猜測是,這是問題。你應該嘗試調用它並打印出mysql_data以標準輸出,以確保你所接收到的結果是你所期望的。