国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > Python > 正文

python實(shí)現(xiàn)多人聊天室

2020-02-15 22:51:40
字體:
供稿:網(wǎng)友

本文實(shí)例為大家分享了python實(shí)現(xiàn)多人聊天室的具體代碼,供大家參考,具體內(nèi)容如下

一、目的

以實(shí)現(xiàn)小項(xiàng)目的方式,來鞏固之前學(xué)過的Python基本語法以及相關(guān)的知識(shí)。 

二、相關(guān)技術(shù)

1.wxpython GUI編程

2.網(wǎng)絡(luò)編程

3.多線程編程

4.數(shù)據(jù)庫編程

5.簡(jiǎn)單的將數(shù)據(jù)導(dǎo)出到Excel表 

三、存在的漏洞以及不足

1.由于數(shù)據(jù)庫編碼的問題,無法使用中文。

2.在客戶端關(guān)閉后,其相關(guān)的線程仍然存在于服務(wù)器的用戶線程隊(duì)列中,所以服務(wù)器會(huì)錯(cuò)誤地往已關(guān)閉的客戶端傳送信息。

3.客戶端初始登錄并加載歷史記錄時(shí),會(huì)出現(xiàn)每條歷史消息后面的回車鍵丟失的現(xiàn)象,解決的方法是:在加載相鄰兩條消息之間加個(gè)時(shí)間間隔,但效果不佳。

四、源碼

服務(wù)器Server:

 # -*- coding: UTF-8 -*-from socket import *import timeimport threadingimport wximport MySQLdbimport xlwtfrom clientthread import ClientThreadclass Server(wx.Frame): def __init__(self,parent=None,id=-1,title='服務(wù)器',pos=wx.DefaultPosition,size=(500,300)):  '''窗口'''  wx.Frame.__init__(self,parent,id,title,pos,size=(400,470))  pl = wx.Panel(self)  con = wx.BoxSizer(wx.VERTICAL)  subcon = wx.FlexGridSizer(wx.HORIZONTAL)  sta = wx.Button(pl , size=(133, 40),label='啟動(dòng)服務(wù)器')  end = wx.Button(pl, size=(133, 40), label='關(guān)閉服務(wù)器')  hist = wx.Button(pl,size=(133,40),label='導(dǎo)出聊天記錄')  subcon.Add(sta, 1, wx.BOTTOM)  subcon.Add(hist, 1, wx.BOTTOM)  subcon.Add(end, 1, wx.BOTTOM)  con.Add(subcon,1,wx.ALIGN_CENTRE|wx.BOTTOM)  self.Text = wx.TextCtrl(pl, size=(400,250),style = wx.TE_MULTILINE|wx.TE_READONLY)  con.Add(self.Text, 1, wx.ALIGN_CENTRE)  self.ttex = wx.TextCtrl(pl, size=(400,100),style=wx.TE_MULTILINE)  con.Add(self.ttex, 1, wx.ALIGN_CENTRE)  sub2 = wx.FlexGridSizer(wx.HORIZONTAL)  clear = wx.Button(pl, size=(200, 40), label='清空')  send = wx.Button(pl, size=(200, 40), label='發(fā)送')  sub2.Add(clear, 1, wx.TOP | wx.LEFT)  sub2.Add(send, 1, wx.TOP | wx.RIGHT)  con.Add(sub2, 1, wx.ALIGN_CENTRE)  pl.SetSizer(con)  '''窗口'''  '''綁定'''  self.Bind(wx.EVT_BUTTON, self.EditClear, clear)  self.Bind(wx.EVT_BUTTON, self.SendMessage, send)  self.Bind(wx.EVT_BUTTON, self.Start, sta)  self.Bind(wx.EVT_BUTTON, self.Break, end)  self.Bind(wx.EVT_BUTTON, self.WriteToExcel, hist)  '''綁定'''  '''服務(wù)器準(zhǔn)備工作'''  self.UserThreadList = []  self.onServe = False  addr = ('', 21567)  self.ServeSock = socket(AF_INET, SOCK_STREAM)  self.ServeSock.bind(addr)  self.ServeSock.listen(10)  '''服務(wù)器準(zhǔn)備工作'''  '''數(shù)據(jù)庫準(zhǔn)備工作,用于存儲(chǔ)聊天記錄'''  self.db = MySQLdb.connect('localhost', 'root', '123456', 'user_info')  self.cursor = self.db.cursor()  self.cursor.execute("select * from history order by time")  self.Text.SetValue('')  for data in self.cursor.fetchall(): #加載歷史聊天記錄   self.Text.AppendText('%s said:/n%s/nwhen %s/n/n' % (data[0], data[2], data[1]))  '''數(shù)據(jù)庫準(zhǔn)備工作,用于存儲(chǔ)聊天記錄''' #將聊天記錄導(dǎo)出到EXCEl表中 def WriteToExcel(self,event):  wbk = xlwt.Workbook()  sheet = wbk.add_sheet('sheet 1')  self.cursor.execute("select * from history order by time")  sheet.write(0, 0, "User")  sheet.write(0, 1, "Datetime")  sheet.write(0, 5, "Message")  index = 0  for data in self.cursor.fetchall():   index = index + 1   Time = '%s'%data[1] #將datetime轉(zhuǎn)成字符形式,否則直接寫入Excel會(huì)變成時(shí)間戳   sheet.write(index,0,data[0])   sheet.write(index,1,Time) #寫進(jìn)EXCEL會(huì)變成時(shí)間戳   sheet.write(index,5,data[2])  wbk.save(r'D:/History_Dialog.xls') #啟動(dòng)服務(wù)器的服務(wù)線程 def Start(self,event):  if not self.onServe:   '''啟動(dòng)服務(wù)線程'''   self.onServe = True   mainThread = threading.Thread(target=self.on_serving, args=())   mainThread.setDaemon(True) # 解決父線程結(jié)束,子線程還繼續(xù)運(yùn)行的問題   mainThread.start()   '''啟動(dòng)服務(wù)線程''' #關(guān)閉服務(wù)器 def Break(self,event):  self.onServe = False #服務(wù)器主循環(huán) def on_serving(self):  print '...On serving...'  while self.onServe:   UserSocket, UserAddr = self.ServeSock.accept()   username = UserSocket.recv(1024).decode(encoding='utf-8') #接收用戶名   userthread = ClientThread(UserSocket, username,self)   self.UserThreadList.append(userthread) #將用戶線程加到隊(duì)列中   userthread.start()  self.ServeSock.close() #綁定發(fā)送按鈕 def SendMessage(self,event):  if self.onServe and cmp(self.ttex.GetValue(),''):   data = self.ttex.GetValue()   self.AddText('Server',data,time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))   self.ttex.SetValue('') # 向所有客戶端(包括自己)發(fā)送信息,同時(shí)更新到數(shù)據(jù)庫 def AddText(self, source, data,Time):  self.cursor.execute("insert into history values(/"%s/",/"%s/",/"%s/")" % (source,Time,data)) #雙引號(hào)里面有雙引號(hào),bug:句子不能有雙引號(hào)、以及中文  self.db.commit()  sendData = '%s said:/n%s/nwhen %s/n' % (source,data,Time)  self.Text.AppendText('%s/n'%sendData)  for user in self.UserThreadList:  #bug:客戶端關(guān)閉了仍然在隊(duì)列中。如果客戶端關(guān)閉了,那怎么在服務(wù)器判斷是否已經(jīng)關(guān)閉了?客戶端在關(guān)閉之前發(fā)一條信息給服務(wù)器?   user.UserSocket.send(sendData.encode(encoding='utf-8')) #綁定清空按鈕 def EditClear(self,event):  self.ttex.Clear()def main(): app = wx.App(False) Server().Show() app.MainLoop()if __name__ == '__main__': main()            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
日本调教视频在线观看| 国产网红在线观看| 伊人影院在线播放| 在线伊人免费视频| 在线观看的网站你懂的| 亚洲精品一区中文字幕电影| 国产福利三区| av人人综合网| 久草电影在线| 国产黄a三级三级三级av在线看| 国产精品久久在线| 在线观看视频污| 成人午夜无人区一区二区| 国产精品外围在线观看| 国产性色视频| 啪啪免费视频一区| 91午夜在线| 国产蜜臀在线| 91欧美在线视频| 久青青在线观看视频国产| 国产porn在线| 国产一级在线观看| 2018中文字幕在线观看| 狠狠干五月天| www.国产精品.com| av文字幕在线观看| 国产精品久久久高清免费| 九九热在线观看视频| 91在线网站| 国产欧美日韩精品综合| 青青国产在线| 天天操夜夜添| 一级二级在线观看| 国产精品美女一区二区三区四区| 欧美成人亚洲高清在线观看| 在线视频三区| 精品卡一卡卡2卡3网站| 国产精品㊣新片速递bt| 久热精品免费视频| 亚洲激情丁香| 日本在线观看| 欧美视频免费一区二区三区| 精品网站www| 国产高清在线观看| 国产成人福利| 精品视频二区三区| av文字幕在线观看| av在线1区2区| 欧美日韩在线视频免费观看 | 天堂中文在线观看| 亚洲天堂久久久| 日本成人网址| 久久精品免视着国产成人| 蜜桃av在线免费观看| 日本高清中文字幕二区在线| 欧美黑人乱大交ⅹxxxxx| heisi视频网在线观看| 久久久久久久久久久久久91| 狠狠操五月天| 国产福利图片| 欧美高清视频| 国产黄色在线| av一级在线| 狠狠操视频网站| 国产福利在线免费观看| 四虎国产精品永久在线| 久久亚洲资源| 国产成人无吗| 另类高清dbsm日本tvav| 国产人成在线观看| 青青草视频免费在线观看| 国产美女视频一区二区三区| 国产一级又黄| 日韩亚洲一区中文字幕| 国产麻豆视频网站| 在线国产一级| 国产美女视频一区二区三区| 国产精品自拍亚洲| 中文在线官网天堂| 国产精品偷乱一区二区三区| 99中文字幕一区| 中文字幕在线播放网址| 亚洲а∨精品天堂在线| 五月伊人六月| 国内外激情在线| 人人干在线视频| 午夜羞羞小视频在线观看| 中文字幕不卡免费视频| 一本久中文高清| 国产99在线|亚洲| 国产午夜视频在线观看| 狠狠色综合久久婷婷| 国产丝袜在线| 国产一级片在线| 黄色毛片在线| 人人九九精品| 午夜小视频在线| 一级二级三级在线观看| 91看片在线观看| 中文天堂av| 在线免费看av| 先锋av资源网| 免费一区二区三区视频狠狠| 亚洲视频精品在线观看| 99免费视频| 亚洲激情丁香| 午夜小视频在线| 18被视频免费观看视频| 国产黄色在线| 69精品视频| 伊人资源视频在线| 亚洲精品aaaa| 久久综合第一页| 午夜av在线播放| 国产福利图片| 99热99re6国产在线播放| 9色在线视频网站| 色中文字幕在线| 国产中文伊人| 国产www视频在线观看| 夜夜操com| 懂色av中文在线| 久久久久久77777| 国产欧美日韩精品综合| 性国产高清在线观看| 九九热精品在线视频| 国产一二在线观看| 国产精品久久久久久久牛牛| 国产成人高清精品| 欧美性猛交p30| 国产激情视频在线观看| 99久久免费精品国产免费| av在线第一页| 国产精品综合久久久久| 一区免费观看| √天堂中文在线| gogo高清在线播放免费| 欧美a免费在线| 国产精品日日爱| xxx国产精品| 国产激情二区| 中文字幕免费在线视频| 日本高清不卡中文字幕| 92久久精品| 国产亚洲精品自在线观看| 永久免费在线观看| 国产欧美久久久久久久久| 日本韩国精品一区二区| 精品一区二区三区在线观看l| 久久五月精品中文字幕| 在线国产1区| 精品一二三四| 国产偷窥洗澡视频| 日本电影全部在线观看网站视频| √天堂8资源中文在线| 免费高清av| 青草视频在线播放| 日本黄色免费网址| 一本大道久久a久久精品| 国产精选在线观看| 国产在线高潮| 久久久久久久久久久久网站| 青草在线视频在线观看| 亚洲人av在线| 日本动漫理论片在线观看网站| 在线色视频观看| 尤物视频在线观看视频| 国产www网站| 国产毛片毛片毛片| 午夜av电影| 国产黄色片大全| 在线色视频网| 成av人免费青青久| 国产美女福利在线观看| 国产三区视频在线观看| 国产欧美久久久久久久久| 91www在线观看| 欧美日韩亚洲第一页| 国产麻豆一区二区三区精品| 国产青青草在线| 在线免费观看高清视频色| 天天插天天狠天天透| 久久国产精品黑丝| 久久久久久久久久久久网站| 中文字幕日本三级| 精品一区二区三区在线观看l| 亚洲欧美中文字幕在线观看 | 精品国产免费观看一区| 夜色资源网av在先锋网站观看| 青青在线视频| 中文字幕日本在线观看| 91亚洲欧美| 九色视频网站| 在线免费国产视频| 国产在线视频精品视频免费看| 国产在线高潮| av在线不卡免费| 国产成a人亚洲精v品| 黄色毛片在线观看| 亚洲精品手机在线|