标签:写入文件 while set nbsp bin with open 短信 学习 val
udp是无链接的,启动服务之后可以直接接受消息,不需要提前建立链接
数据报协议(自带报头)
没有双向通道 通信类似于发短信
UDP基本使用
# 客户端 import socket client = socket.socket(type=socket.SOCK_DGRAM) # 不需要建立连接 直接进入通信循环 server_address = (‘127.0.0.1‘,8080) while True: client.sendto(b‘hello‘,server_address) data, addr = client.recvfrom(1024) print(‘服务端发来的数据‘,data) print(‘服务端的地址‘,addr)
# 服务端 import socket server = socket.socket(type=socket.SOCK_DGRAM) server.bind((‘127.0.0.1‘,8080)) # UDP不需要设置半连接池,它也没有半连接池的概念 # 因为没有双向通道 不需要accept 直接就是通信循环 while True: data, addr = server.recvfrom(1024) print(‘数据:‘,data) # 客户端发来的消息 print(‘地址:‘,addr) # 客户端的地址 server.sendto(data.upper(),addr)
1.UDP协议客户端允许发空
2.UDP协议不会黏包
3.UDP协议服务端不存在的情况下,客户端照样不会报错
4.UDP支持并发
UDP类似于发短信
TCP类似于打电话
# 客户端 import socket client = socket.socket(type=socket.SOCK_DGRAM) server_address = (‘127.0.0.1‘,8080) # while True: # msg = input(‘>>>:‘) client.sendto(b‘hello‘,server_address) client.sendto(b‘hello‘,server_address) client.sendto(b‘hello‘,server_address) # data, server_addr = client.recvfrom(1024) # print(data)
#服务端 import socket server = socket.socket(type=socket.SOCK_DGRAM) server.bind((‘127.0.0.1‘,8080)) # while True data, addr = server.recvfrom(1024) print(data) data, addr1 = server.recvfrom(1024) print(data) data, addr2 = server.recvfrom(1024) print(data)
并发:看起来像同时运行
并行:真正意义上的同时运行
# 客户端 import socket import json import os import struct client = socket.socket() client.connect((‘127.0.0.1‘,8080)) while True: # 获取电影列表 循环展示 MOVIE_DIR = r‘F:\TZZ\day26\视频‘ movie_list = os.listdir(MOVIE_DIR) # print(movie_list) for i,movie in enumerate(movie_list,1): print(i,movie) # 用户选择 choice = input(‘please choice movie to upload>>>:‘) # 判断是否是数字 if choice.isdigit(): # 将字符串数字转为int choice = int(choice) - 1 # 判断用户选择在不在列表范围内 if choice in range(0,len(movie_list)): # 获取到用户想上传的文件路径 path = movie_list[choice] # 拼接文件的绝对路径 file_path = os.path.join(MOVIE_DIR,path) # 获取文件大小 file_size = os.path.getsize(file_path) # 定义一个字典 res_d = { ‘file_name‘:‘学习‘, ‘file_size‘:file_size, ‘msg‘:‘好好学习,天天向上‘ } # 序列化字典 json_d = json.dumps(res_d) json_bytes = json_d.encode(‘utf-8‘) # 1.先制作字典格式的报头 header = struct.pack(‘i‘,len(json_bytes)) # 2.发送字典的报头 client.send(header) # 3.再发字典 client.send(json_bytes) # 4.再发文件数据(打开文件循环发送) with open(file_path,‘rb‘) as f: for line in f: client.send(line) else: print(‘not in range‘) else: print(‘must be number‘)
# 服务端 import socket import os import json import struct server = socket.socket() server.bind((‘127.0.0.1‘,8080)) server.listen(5) while True: conn, addr = server.accept() while True: try: header_len = conn.recv(4) # 解析字典报头 header_len = struct.unpack(‘i‘,header_len)[0] # 再接收字典数据 header_dic = conn.recv(header_len) real_dic = json.loads(header_dic.decode(‘utf-8‘)) # 获取数据长度 total_size = real_dic.get(‘file_size‘) # 循环接收并写入文件 recv_size = 0 with open(real_dic.get(‘file_name‘),‘wb‘) as f: while recv_size < total_size: data = conn.recv(1024) f.write(data) recv_size += len(data) print(‘上传成功‘) except ConnectionResetError as e: print(e) break conn.close()
什么是异常?
程序在运行过程中出现了不可预知的错误
并且该错误没有对应的处理机制,那么就会以异常的形式表现出来
造成的影响就是整个程序无法再正常运行
异常的结构
1.异常的类型:NAMEERROR
2.异常的信息:name ‘fdsdfsdf‘ is not defined
3.异常的位置:Traceback (most recent call last):
异常的种类
分为两大类
1.语法错误
是你程序立刻就能解决的,这种错误是不能被容忍的
语法上的错误 发现之后应该立刻解决
2.逻辑错误
这种错是可以被容忍的 因为一眼看不出来
针对逻辑上的错误 可以采用异常处理机制进行捕获
常见的错误类型
NAMERROR 名字错误
SyntaxError 语法错误
KeyError 键不存在
ValueError 值错误
IndexError 索引错误
如何避免
异常处理
在你认为可能会出现bug的代码块上方try一下:注意try内部的代码块越少越好
try:
可能出错的代码
except 出错的类型 as e: # 将报错信息赋值给变量e
出错之后的处理机制
标签:写入文件 while set nbsp bin with open 短信 学习 val
原文地址:https://www.cnblogs.com/TZZ1995/p/11322539.html