标签:util 模块 读取 应用层 网络 nload span 示例 默认
一 进度条
import time def func(size,total_size): val = int(size/total_size * 100) time.sleep(0.1) print(‘\r%s%%|%s‘ %(val,"#"*val,), end=‘‘) for i in range(101): func(i,100)
二 计算文件大小
import os size = os.stat(r‘D:\sylar\s15\day31\1.进度条.py‘).st_size print(size)
三 除文件或者是更改文件名的方法
import os import shutil # py2 + win:报错 # os.rename(‘a.text‘,‘b.txt‘) # py2+py3 shutil.move(‘c.txt‘,‘a.txt‘) # shutil.rmtree(‘D:\sylar\s15\day30‘) 删除文件夹或者是文件
四 网络基础相关
1. 网络基础相关 离线: mac地址 插网线: 路由器 交换机 DHCP IP 子网掩码 网关 访问: 域名/域名解析 - 内网:arp协议+广播+单播(广播风暴) - 外网:网关 创业: - 租服务器(公有云/私有云/docker)/租空间 - 租域名 + 域名解析 - 写代码,然后上传到服务器,运行。 2. socket - TCP和UDP - socket - socketserver+多线程 - 黏包 3. - 端口,是什么?为什么要有? 端口是为了将同一个电脑上的不同程序进行隔离。 IP是找电脑 端口是找电脑上的程序 示例: MySQL是一个软件,软件帮助我们在硬盘上进行文件操作。默认端口:3306 Redis是一个软件,软件帮助我们在内存里进行数据操作。默认端口:6379 网站默认端口:80 ,访问时:http://www.luffycity.com:80 网站默认端口:443 ,访问时:https://www.luffycity.com:443 范围: 1 - 65535 1 - 1024 一般情况: 8000 8001 ... 4. - OSI 7层模型 7层: 自己写的代码:自己代码+框架 应用层,使用软件。 打开软件或网站 表示层,看到数据,如图片和视频。 生产数据:szwwd 会话层,保持登录或链接状态。 应用偷偷携带一点其他数据:令牌 19rRNAwf8GVe6xyT9kJPIu5SlQc socket模块: 传输层,TCP/UDP [TCP][szwwd|19rRNAwf8GVe6xyT9kJPIu5SlQc] 网络层,IP 【IP】【[TCP][szwwd|19rRNAwf8GVe6xyT9kJPIu5SlQc]】 数据链路层,MAC [MAC][【IP】【[TCP][szwwd|19rRNAwf8GVe6xyT9kJPIu5SlQc]】] 物理层,将数据转换成电信号发送 5层: 应用层 应用层 表示层 会话层 传输层 网络层 数据链路层 物理层 4层: 应用层 应用层 表示层 会话层 传输层 网络层 物理层 数据链路层 物理层 注意:7层背会。 5. - TCP三次握手/四次挥手 socket客户端向服务端发起连接请求:三次握手 client.connect((....)) 客户端 服务端 我能打你吗 来呀来呀 好的,我这就来 ----------------------------- client.send(‘发送数据‘) 收发数据 收发数据 客户端和服务端断开连接:四次挥手 client.close() 或 conn.close() ----------------------------- 我要断开连接 断开就断开,等我处理一些手头的事情 ... 我处理完了,断开吧。 拜拜 补充:断开连接时,反应到代码上:抛出异常/发送空内容; 总结:了解网络相关知识。 你与科班出人的人区别: 1. 计算机组成原理 2. 网络 3. 数据结构 4. 算法 牛逼大学的人+考研的人
五 断点续传
#client
import os import socket import json import hashlib CODE = { ‘1001‘:‘上传文件,从头开始上传‘ } def file_md5(file_path): """ 文件进行md5加密 :param file_path: :return: """ obj = open(file_path,‘rb‘) m = hashlib.md5() for line in obj: m.update(line) obj.close() return m.hexdigest() def jdt(size,total_size): """ 显示进度条 :return: """ val = int(size / total_size * 100) print(‘\r%s%%|%s‘ % (val, "#" * val,), end=‘‘) def send_file(exist_size,file_total_size): """ 发送文件 :param exist_size:开始读取字节的位置 :param file_total_size: 文件总字节大小 :return: """ f = open(file_path, ‘rb‘) f.seek(exist_size) send_size = exist_size while send_size < file_total_size: data = f.read(1024) sk.sendall(data) send_size += len(data) jdt(send_size,file_total_size) f.close() print(‘上传成功‘) def upload(file_path): """ 文件上传(含断点) :param file_path: :return: """ file_md5_val = file_md5(file_path) file_name = os.path.basename(file_path) file_size = os.stat(file_path).st_size cmd_dict = {‘cmd‘: ‘upload‘, ‘file_name‘: file_name, ‘size‘: file_size, ‘md5‘: file_md5_val} upload_cmd_bytes = json.dumps(cmd_dict).encode(‘utf-8‘) sk.sendall(upload_cmd_bytes) # 2. 等待服务端的响应 response = json.loads(sk.recv(8096).decode(‘utf-8‘)) if response[‘code‘] == 1001: send_file(0, file_size) else: # 短点续传 exist_size = response[‘size‘] send_file(exist_size,file_size) sk = socket.socket() sk.connect((‘127.0.0.1‘,8001)) while True: # upload|文件路|径 user_input = input("请输入要执行的命令") # 1. 自定义协议{‘cmd‘:‘upload‘,‘file_path‘:‘.....‘} cmd,file_path = user_input.split(‘|‘,maxsplit=1) if cmd == ‘upload‘: upload(file_path) elif cmd == ‘download‘: pass
#server
import os import json import socketserver import shutil CODE = { ‘1001‘:‘上传文件,从头开始上传‘ } def upload(cmd_dict,conn,username): """ 服务端完成上传文件(含断点续传) :param cmd_dict: :param conn: :return: """ # 2. 获取文件信息 file_md5 = cmd_dict[‘md5‘] file_name = cmd_dict[‘file_name‘] file_md5_path = os.path.join(‘home‘, username, file_md5) file_name_path = os.path.join(‘home‘, username, file_name) upload_file_size = cmd_dict[‘size‘] # 3. 判断文件是否存在 exist = os.path.exists(file_md5_path) if not exist: # 不续传 # 3.1.1 可以开始上传了,我已经准备好。 response = {‘code‘: 1001} conn.sendall(json.dumps(response).encode(‘utf-8‘)) # 3.1.2 接收上传的文件内容 f = open(file_md5_path, ‘wb‘) recv_size = 0 while recv_size < upload_file_size: data = conn.recv(1024) f.write(data) f.flush() recv_size += len(data) f.close() # 3.1.3 改名字 shutil.move(file_md5_path, file_name_path) else: # 续传 # 3.2 续传+大小 exist_size = os.stat(file_md5_path).st_size response = {‘code‘: 1002, ‘size‘: exist_size} conn.sendall(json.dumps(response).encode(‘utf-8‘)) f = open(file_md5_path, ‘ab‘) recv_size = exist_size while recv_size < upload_file_size: data = conn.recv(1024) f.write(data) f.flush() recv_size += len(data) f.close() # 3.1.3 改名字 shutil.move(file_md5_path, file_name_path) class NbServer(socketserver.BaseRequestHandler): def handle(self): """ self.request 是客户端的socket对象 :return: """ # 1. 接收命令 upload_cmd_bytes = self.request.recv(8096) cmd_dict = json.loads(upload_cmd_bytes.decode(‘utf-8‘)) if cmd_dict[‘cmd‘] == ‘upload‘: upload(cmd_dict,self.request,‘zhangzijian‘) elif cmd_dict[‘cmd‘] == ‘download‘: pass if __name__ == ‘__main__‘: server = socketserver.ThreadingTCPServer((‘127.0.0.1‘,8001),NbServer) server.serve_forever()
标签:util 模块 读取 应用层 网络 nload span 示例 默认
原文地址:https://www.cnblogs.com/lxx7/p/9607260.html