Python3 notes

简介: Python3 notes

用socket实现的一个简易聊天室功能,支持@用户私聊。

服务端代码:

import socket

import threading


# 客户端地址 名称

addr_name ={}


# 所有客户端

all_clients =[]


# 名称 客户端

name_client ={}


server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)


host = socket.gethostname()


port =9999


server.bind((host, port))


server.listen(5)


lock= threading.Lock()


print("开启聊天室")



def handle_sock(sock, addr):

   whileTrue:

       try:

           data = sock.recv(1024)

           msg = data.decode("utf-8")

           print("send msg")

           from_name = addr_name[str(addr)]

           if msg.startswith('@'):

               index = msg.index(' ')

               # 私聊人                

               to_name = msg[1:index]

               # 接收者客户端              

               to_sock = name_client[to_name]

               # 发送的消息                

               to_msg = msg[index:]

               send_one(to_sock, addr, from_name +":"+ to_msg)

           else:

               # 群发消息                

               send_all(all_clients, addr, from_name +":"+ msg)

       exceptConnectionResetError:

           exit_name = addr_name[str(addr)]

           exit_client = name_client[exit_name]

           all_clients.remove(exit_client)

           msg = exit_name +" 退出了群聊"          

           send_all(all_clients, addr, msg)

           break



def send_all(socks, addr, msg):

   for sock in socks:

       sock.send(msg.encode("utf-8"))



def send_one(sock, addr, msg):

   sock.send(msg.encode("utf-8"))



whileTrue:

   sock, addr = server.accept()

   name = sock.recv(1024).decode("utf-8")

   addr_name[str(addr)]= name

   name_client[name]= sock

   all_clients.append(sock)

   hello = name +"加入了聊天室"    

   send_all(all_clients, addr, hello)

   client_thread = threading.Thread(target=handle_sock, args=(sock, addr))

   client_thread.start()

客户端代码:

import socket

import threading


s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)


host = socket.gethostname()


port =9999s.connect((host, port))

name ="cc"

s.send(name.encode("utf-8"))



def receive_handle(sock, addr):

   whileTrue:

       data = sock.recv(1024)

       print(data.decode("utf-8"))


# 开启线程监听接收消息

receive_thread = threading.Thread(target=receive_handle, args=(s,'1'))

receive_thread.start()


whileTrue:

   re_data = input()

   s.send(re_data.encode("utf-8"))

目录
打赏
0
0
0
0
50
分享
相关文章
MS SQL 表字段增加,删除,修改
1.表字段添加 格式:ALTER TABLE table_name ADD column_name data_type 设置默认值: ALTER TABLE table_name ADD COLUMN column_name VARCHAR (10)  NOT NULL  WITH DEFAULT '02'   MSSQL常用收集Int IDENTITY (1, 1) NOT
1410 0
快速带你上手通义灵码 2.0,体验飞一般的感觉
通义灵码个人版为开发者免费提供智能编码能力,专业版限免期内开放更多功能。使用需先注册阿里云账号,支持JetBrains IDEs、Visual Studio Code等开发工具。以Visual Studio Code为例,安装插件并登录后即可体验其强大功能。通义灵码2.0在代码生成、需求理解及单元测试自动化等方面有显著提升,支持多语言和复杂场景,大幅提高开发效率。
220777 19
快速带你上手通义灵码 2.0,体验飞一般的感觉
利用通义灵码AI在VS Code中快速开发扫雷游戏:Qwen2.5-Max模型的应用实例
本文介绍了如何利用阿里云通义灵码AI程序员的Qwen2.5-Max模型,在VS Code中一键生成扫雷小游戏。通过安装通义灵码插件并配置模型,输入指令即可自动生成包含游戏逻辑与UI设计的Python代码。生成的游戏支持难度选择,运行稳定无Bug。实践表明,AI工具显著提升开发效率,但人机协作仍是未来趋势。建议开发者积极拥抱新技术,同时不断提升自身技能以适应行业发展需求。
22095 10
Agent TARS:一键让AI托管电脑!字节开源PC端多模态AI助手,无缝集成浏览器与系统操作
Agent TARS 是一款开源的多模态AI助手,能够通过视觉解析网页并无缝集成命令行和文件系统,帮助用户高效完成复杂任务。
2257 7
Agent TARS:一键让AI托管电脑!字节开源PC端多模态AI助手,无缝集成浏览器与系统操作
基于阿里百炼的DeepSeek-R1满血版模型调用【零门槛保姆级2084小游戏开发实战】
本文介绍基于阿里百炼的DeepSeek-R1满血版模型调用,提供零门槛保姆级2048小游戏开发实战。文章分为三部分:定位与核心优势、实战部署操作指南、辅助实战开发。通过详细步骤和案例展示,帮助开发者高效利用DeepSeek-R1的强大推理能力,优化游戏逻辑与视觉效果,解决官网响应延迟问题,提升开发效率和用户体验。适合企业开发者、教育行业及多模态探索者使用。
90032 26
基于阿里百炼的DeepSeek-R1满血版模型调用【零门槛保姆级2084小游戏开发实战】
小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
141142 27
小鱼深度评测 | 通义灵码2.0,不仅可跨语言编码,自动生成单元测试,更炸裂的是集成DeepSeek模型且免费使用,太炸裂了。
快速使用 DeepSeek-R1 满血版
DeepSeek是一款基于Transformer架构的先进大语言模型,以其强大的自然语言处理能力和高效的推理速度著称。近年来,DeepSeek不断迭代,从DeepSeek-V2到参数达6710亿的DeepSeek-V3,再到性能比肩GPT-4的DeepSeek-R1,每次都带来重大技术突破。其开源策略降低了AI应用门槛,推动了AI普惠化。通过阿里云百炼调用满血版API,用户可以快速部署DeepSeek,享受高效、低成本的云端服务,最快10分钟完成部署,且提供免费token,极大简化了开发流程。
191214 28
快速使用 DeepSeek-R1 满血版