百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

小白之Tkinter库读文:其他功能-网络功能(51)

liuian 2025-06-10 16:27 8 浏览

5.11 网络功能

说明

Tkinter 可以通过 Python 的网络模块实现网络通信功能。常用的网络通信方式包括:

  1. 使用 socket 模块:实现底层的网络通信(如 TCP/UDP)。
  2. 使用第三方库(如 requests):实现 HTTP 请求,适合与 Web API 交互。

方法

socket 模块

  • 用于实现 TCP/UDP 通信。
  • 适合需要自定义协议或实时通信的场景。

requests 库

  • 用于发送 HTTP 请求(如 GET、POST)。
  • 适合与 Web 服务器或 RESTful API 交互。

方法 1:使用socket模块

参数说明

  • socket.socket(family, type):创建套接字。
    • family:地址族(如 socket.AF_INET 表示 IPv4)。
    • type:套接字类型(如 socket.SOCK_STREAM 表示 TCP,socket.SOCK_DGRAM 表示 UDP)。
  • socket.bind(address):绑定地址和端口。
    • address:元组 (host, port)。
  • socket.listen(backlog):开始监听连接(TCP)。
    • backlog:最大等待连接数。
  • socket.accept():接受连接(TCP)。
  • socket.connect(address):连接到服务器。
  • socket.send(data):发送数据。
  • socket.recv(buffer_size):接收数据。

案例演示

以下是一个简单的 TCP 客户端和服务器示例。

1. TCP 服务器

import socket

# 创建 TCP 服务器
def start_server():
    server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_socket.bind(("0.0.0.0", 12345))  # 绑定地址和端口
    server_socket.listen(5)  # 开始监听
    print("服务器已启动,等待连接...")

    while True:
        client_socket, addr = server_socket.accept()  # 接受连接
        print(f"客户端 {addr} 已连接")
        data = client_socket.recv(1024)  # 接收数据
        print(f"收到数据: {data.decode()}")
        client_socket.send("Hello, Client!".encode())  # 发送数据
        client_socket.close()  # 关闭连接

# 启动服务器
start_server()

2. TCP 客户端

import socket
import tkinter as tk
from tkinter import messagebox

# 发送消息到服务器
def send_message():
    client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    client_socket.connect(("127.0.0.1", 12345))  # 连接到服务器
    message = entry_message.get()
    client_socket.send(message.encode())  # 发送数据
    response = client_socket.recv(1024)  # 接收数据
    messagebox.showinfo("服务器响应", response.decode())
    client_socket.close()  # 关闭连接

# 创建主窗口
root = tk.Tk()
root.title("TCP 客户端")
root.geometry("300x150")

# 输入框和按钮
tk.Label(root, text="消息:").pack(pady=10)
entry_message = tk.Entry(root, width=30)
entry_message.pack(pady=10)
tk.Button(root, text="发送", command=send_message).pack(pady=10)

# 运行主事件循环
root.mainloop()

运行效果



  1. 启动服务器后,等待客户端连接。
  2. 运行客户端程序,输入消息并点击“发送”。
  3. 服务器收到消息并返回响应,客户端显示响应内容。

方法 2:使用requests库

参数说明

  • requests.get(url, params=None):发送 GET 请求。
    • url:请求的 URL。
    • params:查询参数(字典形式)。
  • requests.post(url, data=None, json=None):发送 POST 请求。
    • url:请求的 URL。
    • data:表单数据(字典形式)。
    • json:JSON 数据(字典形式)。
  • response.status_code:HTTP 状态码。
  • response.text:响应内容(字符串形式)。
  • response.json():响应内容(JSON 格式)。

案例演示

以下是一个示例,展示如何使用 requests 库与 Web API 交互。

1. 安装requests

首先安装库:

pip install requests

2. 创建 Tkinter 应用程序

import tkinter as tk
from tkinter import messagebox
import requests

# 发送 HTTP 请求
def fetch_data():
    url = entry_url.get()
    try:
        response = requests.get(url)
        if response.status_code == 200:
            text_response.delete(1.0, tk.END)
            text_response.insert(tk.END, response.text)
        else:
            messagebox.showerror("错误", f"请求失败,状态码: {response.status_code}")
    except requests.exceptions.RequestException as e:
        messagebox.showerror("错误", f"请求异常: {e}")

# 创建主窗口
root = tk.Tk()
root.title("HTTP 请求示例")
root.geometry("500x400")

# 输入框和按钮
tk.Label(root, text="URL:").pack(pady=10)
entry_url = tk.Entry(root, width=50)
entry_url.pack(pady=10)
tk.Button(root, text="发送请求", command=fetch_data).pack(pady=10)

# 响应显示
text_response = tk.Text(root, width=60, height=20)
text_response.pack(pady=10)

# 运行主事件循环
root.mainloop()

代码说明

发送 HTTP 请求

  • 使用 requests.get 发送 GET 请求。
  • 根据响应状态码和内容更新界面。

Tkinter 界面

  • 使用 Entry 控件输入 URL。
  • 使用 Button 控件触发请求。
  • 使用 Text 控件显示响应内容。

运行效果



  1. 运行程序后,显示一个输入框和一个“发送请求”按钮。
  2. 输入 URL,点击按钮。
  3. 响应内容会显示在文本框中。

注意事项

错误处理

  • 使用 try-except 捕获网络请求中的异常。

性能优化

  • 对于大量请求,可以使用多线程或异步编程避免界面冻结。

安全性

  • 避免在请求中传输敏感信息,或使用 HTTPS 加密通信。

通过 socket 或 requests,可以轻松实现 Tkinter 应用程序的网络功能,满足不同的通信需求。

相关推荐

办公小技巧:定时提醒不慌张 Excel制作智能提醒器

平时工作或学习中总有许多事情需要提醒,比如参加高考的日子、女友的生日、每周例会等。我们可以利用Excel的函数制作实用的智能提醒器,就不用担心忽略这些重要的日子了。每周例会轻松提醒公司规定每个月的最后...

使用vba将Excel 文件转成 CSV 文件

使用vba将Excel中的内容写入文本文件,保存为txt或csv格式。方法一:SubtoCSV()DimshtAsWorksheetDimiAsInteger,j...

用Excel编写俄罗斯方块(vb做俄罗斯方块)

看到这个题目,想必你一定会感到非常惊讶,什么,Excel居然能开发游戏?没错,Excel的强大取决于使用者,遇强则强,遇弱则弱。但我这篇文章并不是为了展示Excel使用过程中的奇技淫巧,而是主要写给那...

该死的手抄滚开(该死的手抄滚开表情包)

碰到形式主义惯犯或硬拔存在感的,顶不住要手抄怎么办?电脑时代这一切都不是问题,除了纸张背面少点中性笔划下的凸痕。网络上有大量的手写体,比较大众化(就是丑)的有李国夫手写体、陈静的字体、萌妹子等,我们也...

Excel二维表转换一维表,三种方法一网打尽!

今天高顿网校小编向大家分享二维表格转一维表的三种方法,分别用到函数、数据透视表和VBA代码。三种方法各有利弊,表亲可以自行选择。如下图,A1:E5是数据源,A7:C22是最终要实现的结果样式:一起动手...

PMC用到的所有函数,大咖总结,实用干货,PMC必备神器!

PMC用到的所有函数你和PMC大咖之间的差异,就是这些Excel函数!1.PMC日常用到的所有函数如下,大咖总结,实用干货,PMC必备神器!每个函数都有实例讲解,不怕你不会。序号PMC工作需求EXCE...

Excel VBA应用-13:统计业务员业绩,目标完成率分析表

在评价业务员销售业绩时,往往会给业务员设定销售目标,根据实际业务计算业务员的目标完成率。报表格式如下图:要计算目标完成率,首先要有销售目标的数据,可以在Excel表中建立一个销售目标表,这种方式的好处...

VBA高级应用30例应用2实现在列表框内及列表框间实现数据拖动

《VBA高级应用30例》(版权10178985),是我推出的第十套教程,教程是专门针对高级学员在学习VBA过程中提高路途上的案例展开,这套教程案例与理论结合,紧贴“实战”,并做“战术总结”,以便大家能...

技术分析:一款流行的VBA宏病毒(vba宏是什么)

1.通过邮件传播的宏病毒近期流行的一个宏病毒通过邮件进行传播,捕捉到的一个样本,其邮件头如下:邮件的内容是这样子的(为节省篇幅,省略号处省略部分内容):YourbillsummaryAccount...

Excel规划求解怎么用?最简单的3*3不同数字填充技...

Excel有什么样的功能,它到底有多强大?Excel表格中有函数公式、图表、操作技巧、vba操作等不同类型的使用方法,但还有一种更加重要的用法就是数据分析,需要用到的就是我们的Excel规划求解。规划...

excel vba vb.net考勤时间处理通用方法(2)

接上期:excelvbavb.net考勤时间处理通用方法(1)DimstartTicksAsIntegerstartTicks=My.Computer.Clock.Ti...

aardio + VBA ( Excel ) 快速开发,3 分钟可入门

aardio很小,下载就可以使用,没有任何复杂步骤。aardio与ExcelVBA(兼容WPSJSA)可以相互调用函数,不需要任何复杂的封装。3分钟够用,下面开始:一、aardio...

VBA+SQL实战:根据时间智能匹配比赛场次,获取最近3场比赛数据

“每天有大量比赛数据,如何快速判断某时间属于哪一场比赛,并自动获取最近3场记录?”本文介绍VBA和SQL双方案,实现:自动匹配时间所属场次(如“第一场/第二场/第三场”)智能返回最近3场比赛数据(跨...

Excel VBA 每天一段代码:自定义分页函数

3月12日视频《ExcelVBA网友答疑:ActiveX控件实现数据分页、翻页》中,我自定义了函数窗体数据查询(),现将代码公布如下:参数说明:1、ItemNum每页显示的数据数量(由复合框下...

VBA布尔矩阵筛选在财会场景的六大高阶应用

基于内存位运算与矩阵预编译技术,布尔矩阵可大幅提升财务数据处理效率。以下是针对2025年财务自动化需求的创新实践案例,覆盖审计、税务、合并报表等核心场景:1.多维度税务异常检测场景:在500万条交易...