当前位置: 首页 > web >正文

Python开发功能项目

以下是一篇关于Python开发功能的文章,包含项目和代码示例:

 

用Python开发简单的IM聊天工具

 

即时通讯工具在日常生活和工作中应用广泛。下面将介绍如何使用Python开发一个基础的IM聊天工具,包括客户端和服务端架构、实时消息发送与接收、多用户聊天支持以及一个简单的图形用户界面(GUI)。

 

IM工具的架构设计

 

IM工具通常采用客户端 - 服务器架构。服务端负责管理用户的连接,转发消息到指定用户,确保消息的实时性和可靠性。客户端负责用户输入和消息发送,同时接收来自服务端的消息并展示给用户。采用Python的socket模块构建网络通信,使用threading实现多线程来处理多个用户的连接,并使用tkinter开发客户端的图形界面。

 

服务端的实现

 

服务端负责监听客户端连接,接收和转发消息。以下是服务端代码:

 

import socket

import threading

 

# 保存已连接的客户端

clients = []

 

# 处理客户端消息

def handle_client(client_socket, client_address):

    print(f"(连接成功) {client_address}")

    while True:

        try:

            # 接收消息

            message = client_socket.recv(1024).decode('utf-8')

            if message:

                print(f"(收到消息) {client_address}: {message}")

                # 广播消息给其他客户端

                broadcast(message, client_socket)

            else:

                remove_client(client_socket)

                break

        except:

            remove_client(client_socket)

            break

 

# 广播消息

def broadcast(message, sender_socket):

    for client in clients:

        if client != sender_socket:

            try:

                client.send(message.encode('utf-8'))

            except:

                remove_client(client)

 

# 移除客户端

def remove_client(client_socket):

    if client_socket in clients:

        clients.remove(client_socket)

        print(f"(断开连接) {client_socket.getpeername()}")

 

# 服务端主程序

def server_program():

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

    server.bind(('0.0.0.0', 12345)) # 监听所有IP,端口号12345

    server.listen(5)

    print("(服务器启动) 正在监听连接...")

    while True:

        client_socket, client_address = server.accept()

        clients.append(client_socket)

        threading.Thread(target=handle_client, args=(client_socket, client_address)).start()

 

if __name__ == "__main__":

    server_program()

 

 

客户端的实现

 

客户端需要能够发送消息给服务端,同时接收来自服务端的广播消息,并且有一个简单的GUI来提升用户体验。以下是客户端代码:

 

import socket

import threading

import tkinter as tk

from tkinter import scrolledtext

 

class ChatClient:

    def __init__(self, host='127.0.0.1', port=12345):

        self.client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

        self.client_socket.connect((host, port))

 

        # 创建主窗口

        self.root = tk.Tk()

        self.root.title("IM聊天工具")

        self.root.geometry("400x500")

 

        # 消息显示区域

        self.chat_area = scrolledtext.ScrolledText(self.root, wrap=tk.WORD, state='disabled')

        self.chat_area.pack(padx=10, pady=10, fill=tk.BOTH, expand=True)

 

        # 消息输入框

        self.message_entry = tk.Entry(self.root)

        self.message_entry.pack(padx=10, pady=5, fill=tk.X)

        self.message_entry.bind("<Return>", self.send_message)

 

        # 发送按钮

        self.send_button = tk.Button(self.root, text="发送", command=self.send_message)

        self.send_button.pack(padx=10, pady=5)

 

        # 启动接收线程

        threading.Thread(target=self.receive_messages, daemon=True).start()

 

        # 运行主窗口

        self.root.mainloop()

 

    def send_message(self, event=None):

        message = self.message_entry.get()

        if message:

            self.client_socket.send(message.encode('utf-8'))

            self.message_entry.delete(0, tk.END)

 

    def receive_messages(self):

        while True:

            try:

                message = self.client_socket.recv(1024).decode('utf-8')

                if message:

                    self.chat_area.config(state='normal')

                    self.chat_area.insert(tk.END, message + '\n')

                    self.chat_area.config(state='disabled')

            except:

                break

 

 

这个IM聊天工具只是一个基础示例,可以根据实际需求进一步扩展和完善,如添加用户认证、文件传输、表情支持等功能。

http://www.xdnf.cn/news/13904.html

相关文章:

  • ‌CDGP|数据治理与AI人工智能:相互依存,互相赋能的新篇章
  • uni-app项目怎么实现多服务环境切换
  • 企业不同发展阶段平衡品牌建设和利润获取的策略-中小企实战运营和营销工作室博客
  • 方法 | B2B营销主题品牌化
  • [vela os_1] docs | Kconfig
  • ff数据解析和解码
  • 多模态AI爬虫:文本+图像智能抓取实战
  • 【cv学习笔记】YOLO系列笔记
  • FFmpeg是什么?
  • 怎么轻松实现报表跨库移植
  • 循环数组中相邻元素的最大差值
  • DEVICENET转MODBUS TCP网关连接ABB机器人配置案例
  • 【android bluetooth 框架分析 04】【bt-framework 层详解 5】【AbstractionLayer介绍】
  • JAVA:深入理解 wait() 和 sleep() 的区别与实战
  • 78Qt窗口_QStatusBar的基本使用
  • centos6.5 老旧系统编译glib-2.58.3.tar.bz2
  • mesh转solid freecad
  • OpenCV——图像基本操作(三)
  • 【开发常用命令】:docker常用命令
  • preload、preconnect、prefetch 的作用
  • day033-备份服务rsync
  • Pytorch中view函数详解和工程实战示例
  • docker compose的变量使用说明
  • 【完整源码+数据集+部署教程】太阳能板灰尘检测系统源码和数据集:改进yolo11-LVMB
  • 京津冀城市群13城市空间权重0-1矩阵
  • Rosetta 2介绍
  • 第三章支线七 ·路由边境 · 多页世界的穿梭之术
  • 【MicronTech】eMMC 部件编号解析
  • flutter 的lottie执行一次动画后关闭
  • Windows美化终端、安装wsl和docker