亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

python實現多人聊天室

2020-02-15 22:51:40
字體:
來源:轉載
供稿:網友

本文實例為大家分享了python實現多人聊天室的具體代碼,供大家參考,具體內容如下

一、目的

以實現小項目的方式,來鞏固之前學過的Python基本語法以及相關的知識。 

二、相關技術

1.wxpython GUI編程

2.網絡編程

3.多線程編程

4.數據庫編程

5.簡單的將數據導出到Excel表 

三、存在的漏洞以及不足

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

2.在客戶端關閉后,其相關的線程仍然存在于服務器的用戶線程隊列中,所以服務器會錯誤地往已關閉的客戶端傳送信息。

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

四、源碼

服務器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='服務器',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='啟動服務器')  end = wx.Button(pl, size=(133, 40), label='關閉服務器')  hist = wx.Button(pl,size=(133,40),label='導出聊天記錄')  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='發送')  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)  '''綁定'''  '''服務器準備工作'''  self.UserThreadList = []  self.onServe = False  addr = ('', 21567)  self.ServeSock = socket(AF_INET, SOCK_STREAM)  self.ServeSock.bind(addr)  self.ServeSock.listen(10)  '''服務器準備工作'''  '''數據庫準備工作,用于存儲聊天記錄'''  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]))  '''數據庫準備工作,用于存儲聊天記錄''' #將聊天記錄導出到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轉成字符形式,否則直接寫入Excel會變成時間戳   sheet.write(index,0,data[0])   sheet.write(index,1,Time) #寫進EXCEL會變成時間戳   sheet.write(index,5,data[2])  wbk.save(r'D:/History_Dialog.xls') #啟動服務器的服務線程 def Start(self,event):  if not self.onServe:   '''啟動服務線程'''   self.onServe = True   mainThread = threading.Thread(target=self.on_serving, args=())   mainThread.setDaemon(True) # 解決父線程結束,子線程還繼續運行的問題   mainThread.start()   '''啟動服務線程''' #關閉服務器 def Break(self,event):  self.onServe = False #服務器主循環 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) #將用戶線程加到隊列中   userthread.start()  self.ServeSock.close() #綁定發送按鈕 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('') # 向所有客戶端(包括自己)發送信息,同時更新到數據庫 def AddText(self, source, data,Time):  self.cursor.execute("insert into history values(/"%s/",/"%s/",/"%s/")" % (source,Time,data)) #雙引號里面有雙引號,bug:句子不能有雙引號、以及中文  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:客戶端關閉了仍然在隊列中。如果客戶端關閉了,那怎么在服務器判斷是否已經關閉了?客戶端在關閉之前發一條信息給服務器?   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()            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产中字| 国产有码在线一区二区视频| 国产精品稀缺呦系列在线| 91精品成人久久| 亚洲一区美女视频在线观看免费| 伊人亚洲福利一区二区三区| 精品久久中文字幕久久av| 国产成人久久精品| 欧美精品生活片| 成人国产在线激情| 亚洲免费av电影| 亚洲欧美国产va在线影院| 亚洲综合在线播放| 欧美性猛交xxxx久久久| 97视频人免费观看| 日韩二区三区在线| 欧美日韩国产精品一区二区三区四区| 97国产一区二区精品久久呦| 欧美在线视频网| 亚洲男人天堂九九视频| 欧美专区第一页| 亚洲日本中文字幕免费在线不卡| 欧洲成人午夜免费大片| 亚洲成人激情在线观看| 国产精品自拍偷拍视频| 精品国产福利视频| 狠狠色狠色综合曰曰| 日韩欧美精品网址| 久久综合国产精品台湾中文娱乐网| 日韩精品久久久久久福利| 日本精品免费一区二区三区| 亚洲精品第一国产综合精品| 国外成人性视频| 2019日本中文字幕| 久久久久久久999| www国产亚洲精品久久网站| 九九热最新视频//这里只有精品| 日本亚洲欧美三级| 国产精品自产拍在线观看| 欧美日韩一区二区三区在线免费观看| 日韩av免费一区| 国产精品成人aaaaa网站| 疯狂做受xxxx欧美肥白少妇| 日韩有码在线播放| 国产精品jizz在线观看麻豆| 亚洲欧美中文日韩在线v日本| 欧美最猛性xxxxx(亚洲精品)| 国产在线播放91| 国产精品欧美日韩一区二区| 97视频在线免费观看| 久久九九有精品国产23| 久久久精品2019中文字幕神马| 美女啪啪无遮挡免费久久网站| 欧美大片第1页| 久久91亚洲精品中文字幕| 亚洲人成网站色ww在线| 成人欧美在线观看| 麻豆精品精华液| 国产精品海角社区在线观看| 亚洲国产精品99久久| 日本高清+成人网在线观看| 最近2019年中文视频免费在线观看| 久久久999成人| 色偷偷av一区二区三区| 日韩电影中文字幕一区| 亚洲免费视频网站| 亚洲国产欧美在线成人app| 久久激情视频久久| 亚洲精品97久久| 日韩精品一区二区三区第95| 91香蕉嫩草神马影院在线观看| 夜夜嗨av色一区二区不卡| 尤物九九久久国产精品的分类| 亚洲一区二区在线| 久久久亚洲福利精品午夜| 亚洲欧美中文另类| 欧美国产日本高清在线| 在线精品国产成人综合| 一本久久综合亚洲鲁鲁| 色妞在线综合亚洲欧美| 97超碰国产精品女人人人爽| 国产狼人综合免费视频| 久久久久国色av免费观看性色| 久久久久久久激情视频| 黄色一区二区在线观看| 欧美高清视频在线观看| 欧美一区二区三区四区在线| 亚洲黄色有码视频| 中文字幕精品一区久久久久| 亚洲曰本av电影| 久久国产精品久久精品| 欧美一乱一性一交一视频| 国产成人精彩在线视频九色| 国产色婷婷国产综合在线理论片a| 国内精品久久久久影院 日本资源| 成人午夜在线影院| 欧美性猛交xxxx免费看| 最近日韩中文字幕中文| 国产精品久久一区| 自拍偷拍亚洲欧美| 亚洲免费高清视频| 精品偷拍一区二区三区在线看| 国产一区二区三区欧美| 色狠狠av一区二区三区香蕉蜜桃| 丝袜情趣国产精品| 亚洲成人黄色在线观看| 欧美日韩一区二区三区在线免费观看| 久久91亚洲精品中文字幕奶水| 91精品久久久久| 91精品视频在线| 91精品国产乱码久久久久久蜜臀| 狠狠躁夜夜躁人人躁婷婷91| 亚洲精品v天堂中文字幕| 亚洲女人被黑人巨大进入al| 亚洲精品国精品久久99热一| 亚洲精品99999| 日韩久久午夜影院| 日韩美女中文字幕| 中文字幕在线亚洲| 日韩麻豆第一页| 午夜精品一区二区三区在线视| 日韩一二三在线视频播| 精品电影在线观看| 综合激情国产一区| 亚洲bt天天射| 欧美激情在线视频二区| 丁香五六月婷婷久久激情| 欧美日韩aaaa| 日本久久久久久久久久久| 美女国内精品自产拍在线播放| 欧美人与性动交a欧美精品| 欧美中文在线免费| 欧美精品videos性欧美| 久久综合伊人77777尤物| 久久影院中文字幕| 中文字幕精品一区二区精品| 亚洲精品久久久久久久久久久久| 国产精品黄色影片导航在线观看| 亚洲天堂免费观看| 亚洲欧美日韩国产中文专区| 91精品国产高清| 91免费在线视频网站| 国产精品亚发布| 国产一区二区日韩精品欧美精品| www.亚洲一二| 国产深夜精品福利| 精品视频在线播放| 中文字幕av日韩| 亚洲精品99久久久久| 成人av.网址在线网站| 亚洲欧美国产一区二区三区| 久久久久久久久综合| 热久久免费国产视频| 上原亚衣av一区二区三区| 久久夜色精品国产欧美乱| 国产精品扒开腿爽爽爽视频| 亚洲免费人成在线视频观看| 亚洲欧美综合区自拍另类| 国产精品久久久久久久久久东京| 欧美—级a级欧美特级ar全黄| 久久久亚洲国产天美传媒修理工| 欧美一级视频一区二区| 日韩国产精品亚洲а∨天堂免| 日韩av在线网址|