国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
實(shí)現(xiàn)思路
實(shí)現(xiàn)方式
首頁 后端開發(fā) Python教程 用Python編寫簡(jiǎn)單的聊天程序教程

用Python編寫簡(jiǎn)單的聊天程序教程

May 08, 2023 pm 06:37 PM
python 小程序

實(shí)現(xiàn)思路

x01 服務(wù)端的建立

首先,在服務(wù)端,使用socket進(jìn)行消息的接受,每接受一個(gè)socket的請(qǐng)求,就開啟一個(gè)新的線程來管理消息的分發(fā)與接受,同時(shí),又存在一個(gè)handler來管理所有的線程,從而實(shí)現(xiàn)對(duì)聊天室的各種功能的處理

x02 客戶端的建立

客戶端的建立就要比服務(wù)端簡(jiǎn)單多了,客戶端的作用只是對(duì)消息的發(fā)送以及接受,以及按照特定的規(guī)則去輸入特定的字符從而實(shí)現(xiàn)不同的功能的使用,因此,在客戶端這里,只需要去使用兩個(gè)線程,一個(gè)是專門用于接受消息,一個(gè)是專門用于發(fā)送消息的

至于為什么不用一個(gè)呢,那是因?yàn)?只用一個(gè)的話,當(dāng)接受了消息,在發(fā)送之前接受消息的處于阻塞狀態(tài),同理,發(fā)送消息也是,那么要是將這兩個(gè)功能放在一個(gè)地方實(shí)現(xiàn),就會(huì)導(dǎo)致沒有辦法連續(xù)發(fā)送或者接受消息了

實(shí)現(xiàn)方式

服務(wù)端實(shí)現(xiàn)

如何用python實(shí)現(xiàn)簡(jiǎn)單的聊天小程序

如何用python實(shí)現(xiàn)簡(jiǎn)單的聊天小程序

import?json
import?threading
from?socket?import?*
from?time?import?ctime


class?PyChattingServer:
????__socket?=?socket(AF_INET,?SOCK_STREAM,?0)
????__address?=?('',?12231)

????__buf?=?1024

????def?__init__(self):
????????self.__socket.bind(self.__address)
????????self.__socket.listen(20)
????????self.__msg_handler?=?ChattingHandler()

????def?start_session(self):
????????print('等待客戶連接...\r\n')
????????try:
????????????while?True:
????????????????cs,?caddr?=?self.__socket.accept()
????????????????#?利用handler來管理線程,實(shí)現(xiàn)線程之間的socket的相互通信
????????????????self.__msg_handler.start_thread(cs,?caddr)
????????except?socket.error:
????????????pass


class?ChattingThread(threading.Thread):
????__buf?=?1024

????def?__init__(self,?cs,?caddr,?msg_handler):
????????super(ChattingThread,?self).__init__()
????????self.__cs?=?cs
????????self.__caddr?=?caddr
????????self.__msg_handler?=?msg_handler

????#?使用多線程管理會(huì)話
????def?run(self):
????????try:
????????????print('...連接來自于:',?self.__caddr)
????????????data?=?'歡迎你到來PY_CHATTING!請(qǐng)輸入你的很cooooool的昵稱(不能帶有空格喲`)\r\n'
????????????self.__cs.sendall(bytes(data,?'utf-8'))
????????????while?True:
????????????????data?=?self.__cs.recv(self.__buf).decode('utf-8')
????????????????if?not?data:
????????????????????break
????????????????self.__msg_handler.handle_msg(data,?self.__cs)
????????????????print(data)
????????except?socket.error?as?e:
????????????print(e.args)
????????????pass
????????finally:
????????????self.__msg_handler.close_conn(self.__cs)
????????????self.__cs.close()


class?ChattingHandler:
????__help_str?=?"[?SYSTEM?]\r\n"?\
?????????????????"輸入/ls,即可獲得所有登陸用戶信息\r\n"?\
?????????????????"輸入/h,即可獲得幫助\r\n"?\
?????????????????"輸入@用戶名?(注意用戶名后面的空格)+消息,即可發(fā)動(dòng)單聊\r\n"?\
?????????????????"輸入/i,即可屏蔽群聊信息\r\n"?\
?????????????????"再次輸入/i,即可取消屏蔽\r\n"?\
?????????????????"所有首字符為/的信息都不會(huì)發(fā)送出去"

????__buf?=?1024
????__socket_list?=?[]

????__user_name_to_socket?=?{}
????__socket_to_user_name?=?{}

????__user_name_to_broadcast_state?=?{}

????def?start_thread(self,?cs,?caddr):
????????self.__socket_list.append(cs)
????????chat_thread?=?ChattingThread(cs,?caddr,?self)
????????chat_thread.start()

????def?close_conn(self,?cs):
????????if?cs?not?in?self.__socket_list:
????????????return
????????#?去除socket的記錄
????????nickname?=?"SOMEONE"
????????if?cs?in?self.__socket_list:
????????????self.__socket_list.remove(cs)
????????#?去除socket與username之間的映射關(guān)系
????????if?cs?in?self.__socket_to_user_name:
????????????nickname?=?self.__socket_to_user_name[cs]
????????????self.__user_name_to_socket.pop(self.__socket_to_user_name[cs])
????????????self.__socket_to_user_name.pop(cs)
????????????self.__user_name_to_broadcast_state.pop(nickname)
????????nickname?+=?"?"
????????#?廣播某玩家退出聊天室
????????self.broadcast_system_msg(nickname?+?"離開了PY_CHATTING")

????#?管理用戶輸入的信息
????def?handle_msg(self,?msg,?cs):
????????js?=?json.loads(msg)
????????if?js['type']?==?"login":
????????????if?js['msg']?not?in?self.__user_name_to_socket:
????????????????if?'?'?in?js['msg']:
????????????????????self.send_to(json.dumps({
????????????????????????'type':?'login',
????????????????????????'success':?False,
????????????????????????'msg':?'賬號(hào)不能夠帶有空格'
????????????????????}),?cs)
????????????????else:
????????????????????self.__user_name_to_socket[js['msg']]?=?cs
????????????????????self.__socket_to_user_name[cs]?=?js['msg']
????????????????????self.__user_name_to_broadcast_state[js['msg']]?=?True
????????????????????self.send_to(json.dumps({
????????????????????????'type':?'login',
????????????????????????'success':?True,
????????????????????????'msg':?'昵稱建立成功,輸入/ls可查看所有在線的人,輸入/help可以查看幫助(所有首字符為/的消息都不會(huì)發(fā)送)'
????????????????????}),?cs)
????????????????????#?廣播其他人,他已經(jīng)進(jìn)入聊天室
????????????????????self.broadcast_system_msg(js['msg']?+?"已經(jīng)進(jìn)入了聊天室")
????????????else:
????????????????self.send_to(json.dumps({
????????????????????'type':?'login',
????????????????????'success':?False,
????????????????????'msg':?'賬號(hào)已存在'
????????????????}),?cs)
????????#?若玩家處于屏蔽模式,則無法發(fā)送群聊消息
????????elif?js['type']?==?"broadcast":
????????????if?self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]:
????????????????self.broadcast(js['msg'],?cs)
????????????else:
????????????????self.send_to(json.dumps({
????????????????????'type':?'broadcast',
????????????????????'msg':?'屏蔽模式下無法發(fā)送群聊信息'
????????????????}),?cs)
????????elif?js['type']?==?"ls":
????????????self.send_to(json.dumps({
????????????????'type':?'ls',
????????????????'msg':?self.get_all_login_user_info()
????????????}),?cs)
????????elif?js['type']?==?"help":
????????????self.send_to(json.dumps({
????????????????'type':?'help',
????????????????'msg':?self.__help_str
????????????}),?cs)
????????elif?js['type']?==?"sendto":
????????????self.single_chatting(cs,?js['nickname'],?js['msg'])
????????elif?js['type']?==?"ignore":
????????????self.exchange_ignore_state(cs)

????def?exchange_ignore_state(self,?cs):
????????if?cs?in?self.__socket_to_user_name:
????????????state?=?self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]
????????????if?state:
????????????????state?=?False
????????????else:
????????????????state?=?True
????????????self.__user_name_to_broadcast_state.pop(self.__socket_to_user_name[cs])
????????????self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]?=?state
????????????if?self.__user_name_to_broadcast_state[self.__socket_to_user_name[cs]]:
????????????????msg?=?"通常模式"
????????????else:
????????????????msg?=?"屏蔽模式"
????????????self.send_to(json.dumps({
????????????????'type':?'ignore',
????????????????'success':?True,
????????????????'msg':?'[TIME?:?%s]\r\n[?SYSTEM?]?:?%s\r\n'?%?(ctime(),?"模式切換成功,現(xiàn)在是"?+?msg)
????????????}),?cs)
????????else:
????????????self.send_to({
????????????????'type':?'ignore',
????????????????'success':?False,
????????????????'msg':?'切換失敗'
????????????},?cs)

????def?single_chatting(self,?cs,?nickname,?msg):
????????if?nickname?in?self.__user_name_to_socket:
????????????msg?=?'[TIME?:?%s]\r\n[?%s?CHATTING?TO?%s?]?:?%s\r\n'?%?(
????????????????ctime(),?self.__socket_to_user_name[cs],?nickname,?msg)
????????????self.send_to_list(json.dumps({
????????????????'type':?'single',
????????????????'msg':?msg
????????????}),?self.__user_name_to_socket[nickname],?cs)
????????else:
????????????self.send_to(json.dumps({
????????????????'type':?'single',
????????????????'msg':?'該用戶不存在'
????????????}),?cs)
????????print(nickname)

????def?send_to_list(self,?msg,?*cs):
????????for?i?in?range(len(cs)):
????????????self.send_to(msg,?cs[i])

????def?get_all_login_user_info(self):
????????login_list?=?"[?SYSTEM?]?ALIVE?USER?:?\r\n"
????????for?key?in?self.__socket_to_user_name:
????????????login_list?+=?self.__socket_to_user_name[key]?+?",\r\n"
????????return?login_list

????def?send_to(self,?msg,?cs):
????????if?cs?not?in?self.__socket_list:
????????????self.__socket_list.append(cs)
????????cs.sendall(bytes(msg,?'utf-8'))

????def?broadcast_system_msg(self,?msg):
????????data?=?'[TIME?:?%s]\r\n[?SYSTEM?]?:?%s\r\n'?%?(ctime(),?msg)
????????js?=?json.dumps({
????????????'type':?'system_msg',
????????????'msg':?data
????????})
????????#?屏蔽了群聊的玩家也可以獲得系統(tǒng)的群發(fā)信息
????????for?i?in?range(len(self.__socket_list)):
????????????if?self.__socket_list[i]?in?self.__socket_to_user_name:
????????????????self.__socket_list[i].sendall(bytes(js,?'utf-8'))

????def?broadcast(self,?msg,?cs):
????????data?=?'[TIME?:?%s]\r\n[%s]?:?%s\r\n'?%?(ctime(),?self.__socket_to_user_name[cs],?msg)
????????js?=?json.dumps({
????????????'type':?'broadcast',
????????????'msg':?data
????????})
????????#?沒有的登陸的玩家無法得知消息,屏蔽了群聊的玩家也沒辦法獲取信息
????????for?i?in?range(len(self.__socket_list)):
????????????if?self.__socket_list[i]?in?self.__socket_to_user_name?\
????????????????????and?self.__user_name_to_broadcast_state[self.__socket_to_user_name[self.__socket_list[i]]]:
????????????????self.__socket_list[i].sendall(bytes(js,?'utf-8'))


def?main():
????server?=?PyChattingServer()
????server.start_session()


main()

客戶端的實(shí)現(xiàn)

如何用python實(shí)現(xiàn)簡(jiǎn)單的聊天小程序

如何用python實(shí)現(xiàn)簡(jiǎn)單的聊天小程序

import?json
import?threading
from?socket?import?*

is_login?=?False
is_broadcast?=?True


class?ClientReceiveThread(threading.Thread):
????__buf?=?1024

????def?__init__(self,?cs):
????????super(ClientReceiveThread,?self).__init__()
????????self.__cs?=?cs

????def?run(self):
????????self.receive_msg()

????def?receive_msg(self):
????????while?True:
????????????msg?=?self.__cs.recv(self.__buf).decode('utf-8')
????????????if?not?msg:
????????????????break
????????????js?=?json.loads(msg)
????????????if?js['type']?==?"login":
????????????????if?js['success']:
????????????????????global?is_login
????????????????????is_login?=?True
????????????????print(js['msg'])
????????????elif?js['type']?==?"ignore":
????????????????if?js['success']:
????????????????????global?is_broadcast
????????????????????if?is_broadcast:
????????????????????????is_broadcast?=?False
????????????????????else:
????????????????????????is_broadcast?=?True
????????????????print(js['msg'])
????????????else:
????????????????if?not?is_broadcast:
????????????????????print("[現(xiàn)在處于屏蔽模式]")
????????????????print(js['msg'])


class?ClientSendMsgThread(threading.Thread):

????def?__init__(self,?cs):
????????super(ClientSendMsgThread,?self).__init__()
????????self.__cs?=?cs

????def?run(self):
????????self.send_msg()

????#?根據(jù)不同的輸入格式來進(jìn)行不同的聊天方式
????def?send_msg(self):
????????while?True:
????????????js?=?None
????????????msg?=?input()
????????????if?not?is_login:
????????????????js?=?json.dumps({
????????????????????'type':?'login',
????????????????????'msg':?msg
????????????????})
????????????elif?msg[0]?==?"@":
????????????????data?=?msg.split('?')
????????????????if?not?data:
????????????????????print("請(qǐng)重新輸入")
????????????????????break
????????????????nickname?=?data[0]
????????????????nickname?=?nickname.strip("@")
????????????????if?len(data)?==?1:
????????????????????data.append("?")
????????????????js?=?json.dumps({
????????????????????'type':?'sendto',
????????????????????'nickname':?nickname,
????????????????????'msg':?data[1]
????????????????})
????????????elif?msg?==?"/help":
????????????????js?=?json.dumps({
????????????????????'type':?'help',
????????????????????'msg':?None
????????????????})
????????????elif?msg?==?"/ls":
????????????????js?=?json.dumps({
????????????????????'type':?'ls',
????????????????????'msg':?None
????????????????})
????????????elif?msg?==?"/i":
????????????????js?=?json.dumps({
????????????????????'type':?'ignore',
????????????????????'msg':?None
????????????????})
????????????else:
????????????????if?msg[0]?!=?'/':
????????????????????js?=?json.dumps({
????????????????????????'type':?'broadcast',
????????????????????????'msg':?msg
????????????????????})
????????????if?js?is?not?None:
????????????????self.__cs.sendall(bytes(js,?'utf-8'))


def?main():
????buf?=?1024
????#?改變這個(gè)的地址,變成服務(wù)器的地址,那么只要部署到服務(wù)器上就可以全網(wǎng)使用了
????address?=?("127.0.0.1",?12231)
????cs?=?socket(AF_INET,?SOCK_STREAM,?0)
????cs.connect(address)
????data?=?cs.recv(buf).decode("utf-8")
????if?data:
????????print(data)
????receive_thread?=?ClientReceiveThread(cs)
????receive_thread.start()
????send_thread?=?ClientSendMsgThread(cs)
????send_thread.start()
????while?True:
????????pass


main()

以上是用Python編寫簡(jiǎn)單的聊天程序教程的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

Python類中的多態(tài)性 Python類中的多態(tài)性 Jul 05, 2025 am 02:58 AM

多態(tài)是Python面向?qū)ο缶幊讨械暮诵母拍?,指“一種接口,多種實(shí)現(xiàn)”,允許統(tǒng)一處理不同類型的對(duì)象。1.多態(tài)通過方法重寫實(shí)現(xiàn),子類可重新定義父類方法,如Animal類的speak()方法在Dog和Cat子類中有不同實(shí)現(xiàn)。2.多態(tài)的實(shí)際用途包括簡(jiǎn)化代碼結(jié)構(gòu)、增強(qiáng)可擴(kuò)展性,例如圖形繪制程序中統(tǒng)一調(diào)用draw()方法,或游戲開發(fā)中處理不同角色的共同行為。3.Python實(shí)現(xiàn)多態(tài)需滿足:父類定義方法,子類重寫該方法,但不要求繼承同一父類,只要對(duì)象實(shí)現(xiàn)相同方法即可,這稱為“鴨子類型”。4.注意事項(xiàng)包括保持方

解釋Python發(fā)電機(jī)和迭代器。 解釋Python發(fā)電機(jī)和迭代器。 Jul 05, 2025 am 02:55 AM

迭代器是實(shí)現(xiàn)__iter__()和__next__()方法的對(duì)象,生成器是簡(jiǎn)化版的迭代器,通過yield關(guān)鍵字自動(dòng)實(shí)現(xiàn)這些方法。1.迭代器每次調(diào)用next()返回一個(gè)元素,無更多元素時(shí)拋出StopIteration異常。2.生成器通過函數(shù)定義,使用yield按需生成數(shù)據(jù),節(jié)省內(nèi)存且支持無限序列。3.處理已有集合時(shí)用迭代器,動(dòng)態(tài)生成大數(shù)據(jù)或需惰性求值時(shí)用生成器,如讀取大文件時(shí)逐行加載。注意:列表等可迭代對(duì)象不是迭代器,迭代器到盡頭后需重新創(chuàng)建,生成器只能遍歷一次。

解釋Python斷言。 解釋Python斷言。 Jul 07, 2025 am 12:14 AM

Assert是Python用于調(diào)試的斷言工具,當(dāng)條件不滿足時(shí)拋出AssertionError。其語法為assert條件加可選錯(cuò)誤信息,適用于內(nèi)部邏輯驗(yàn)證如參數(shù)檢查、狀態(tài)確認(rèn)等,但不能用于安全或用戶輸入檢查,且應(yīng)配合清晰提示信息使用,僅限開發(fā)階段輔助調(diào)試而非替代異常處理。

如何一次迭代兩個(gè)列表 如何一次迭代兩個(gè)列表 Jul 09, 2025 am 01:13 AM

在Python中同時(shí)遍歷兩個(gè)列表的常用方法是使用zip()函數(shù),它會(huì)按順序配對(duì)多個(gè)列表并以最短為準(zhǔn);若列表長(zhǎng)度不一致,可使用itertools.zip_longest()以最長(zhǎng)為準(zhǔn)并填充缺失值;結(jié)合enumerate()可同時(shí)獲取索引。1.zip()簡(jiǎn)潔實(shí)用,適合成對(duì)數(shù)據(jù)迭代;2.zip_longest()處理不一致長(zhǎng)度時(shí)可填充默認(rèn)值;3.enumerate(zip())可在遍歷時(shí)獲取索引,滿足多種復(fù)雜場(chǎng)景需求。

什么是Python型提示? 什么是Python型提示? Jul 07, 2025 am 02:55 AM

typeHintsInpyThonsolverbromblemboyofambiguityandPotentialBugSindyNamalytyCodeByallowingDevelopsosteSpecefectifyExpectedTypes.theyenhancereadability,enablellybugdetection,andimprovetool.typehintsupport.typehintsareadsareadsareadsareadsareadsareadsareadsareadsareaddedusidocolon(

什么是Python迭代器? 什么是Python迭代器? Jul 08, 2025 am 02:56 AM

Inpython,IteratorSareObjectSthallowloopingThroughCollectionsByImplementing_iter __()和__next __()。1)iteratorsWiaTheIteratorProtocol,使用__ITER __()toreTurnterateratoratoranteratoratoranteratoratorAnterAnteratoratorant antheittheext__()

如何使對(duì)象成為Python中的發(fā)生器? 如何使對(duì)象成為Python中的發(fā)生器? Jul 07, 2025 am 02:53 AM

要使對(duì)象成為生成器,需通過定義含yield的函數(shù)、實(shí)現(xiàn)\_\_iter\_\_和\_\_next\_\_方法的可迭代類或使用生成器表達(dá)式實(shí)現(xiàn)按需生成值。1.定義含yield的函數(shù),調(diào)用時(shí)返回生成器對(duì)象并逐次生成值;2.在自定義類中實(shí)現(xiàn)\_\_iter\_\_和\_\_next\_\_方法以控制迭代邏輯;3.使用生成器表達(dá)式快速創(chuàng)建輕量級(jí)生成器,適用于簡(jiǎn)單變換或過濾。這些方式均避免將全部數(shù)據(jù)加載至內(nèi)存,從而提升內(nèi)存效率。

如何從c打電話給python? 如何從c打電話給python? Jul 08, 2025 am 12:40 AM

要在C 中調(diào)用Python代碼,首先要初始化解釋器,然后可通過執(zhí)行字符串、文件或調(diào)用具體函數(shù)實(shí)現(xiàn)交互。1.使用Py_Initialize()初始化解釋器并用Py_Finalize()關(guān)閉;2.用PyRun_SimpleString執(zhí)行字符串代碼或PyRun_SimpleFile執(zhí)行腳本文件;3.通過PyImport_ImportModule導(dǎo)入模塊,PyObject_GetAttrString獲取函數(shù),Py_BuildValue構(gòu)造參數(shù),PyObject_CallObject調(diào)用函數(shù)并處理返回

See all articles