Python脚本
update_format.py
批量转视频格式,超级慢,没什么卵用
import os
import asyncio
import subprocess
import concurrent.futures
import tracemalloctracemalloc.start()# 创建日志文件
log_file = open('conversion_log.txt', 'w')async def convert_mkv_to_mp4(input_file, output_file):command = [r'D:\Python Software\ffmpeg-5.1.2-essentials_build\bin\ffmpeg.exe', '-i', input_file, '-codec:v', 'h264','-codec:a', 'aac', output_file]process = await asyncio.create_subprocess_exec(*command, stdout=subprocess.PIPE, stderr=subprocess.PIPE)stdout, stderr = await process.communicate()# 将stdout和stderr写入日志文件log_file.write(f'STDOUT:\n{stdout.decode()}\n')log_file.write(f'STDERR:\n{stderr.decode()}\n')# 等待子进程完成并获取输出,确保它完成await asyncio.sleep(0) # 显式等待,可能帮助消除警告return stdout, stderroutput_folder = rf'D:\tjjg_videos'
os.makedirs(output_folder, exist_ok=True)source_folder = rf'E:\下载'async def convert_files():loop = asyncio.get_event_loop()with concurrent.futures.ThreadPoolExecutor(max_workers=4) as executor:tasks = []for root, dirs, files in os.walk(source_folder):for file in files:if file.endswith('.mkv'):input_file_path = os.path.join(root, file)output_file_path = os.path.join(output_folder, os.path.splitext(file)[0] + '.mp4')# 正确传递参数给 convert_mkv_to_mp4task = await loop.run_in_executor(executor, convert_mkv_to_mp4, input_file_path, output_file_path)tasks.append(task)# 等待所有子任务完成await asyncio.gather(*tasks)if __name__ == '__main__':asyncio.run(convert_files())
update_mp4.py
只批量修改后缀名,但视频属性应该还是原mkv,不过适合我的业务场景
import os
import shutil# 定义源文件夹和目标文件夹的路径
source_folder = r'E:\下载\预算员(土建与装饰)' # 替换为实际的源文件夹路径
target_folder = r'D:\tjjg_videos' # 替换为实际的目标文件夹路径# 确保目标文件夹存在,如果不存在则创建
if not os.path.exists(target_folder):os.makedirs(target_folder)# 遍历源文件夹中的所有文件和子文件夹
for root, _, files in os.walk(source_folder):for filename in files:# 检查文件是否是视频文件(可以根据需要添加其他文件扩展名)if filename.lower().endswith(('.avi', '.mkv', '.mpg', '.mpeg', '.wmv', '.mov', '.flv', '.webm')):source_file_path = os.path.join(root, filename)# 创建新的文件名,将后缀改为.mp4new_filename = '预算员(土建与装饰)' + os.path.splitext(filename)[0] + '.mp4'target_file_path = os.path.join(target_folder, new_filename)# # 移动文件并重命名# shutil.move(source_file_path, target_file_path)# 复制文件并重命名shutil.copy(source_file_path, target_file_path)print('拷贝并重命名完成')
upload_mp4.py
掉接口批量上传
import os
import requests
import time# 目标URL
upload_url = "https://xxxxx.xxxxxx.com/xp/uploads/"# 认证 token
token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoiYWNjZXNzIiwiZXhwIjoxNjk2Mzk5ODAwLCJpYXQiOjE2OTM4MDc4MDAsImp0aSI6IjJmZmZiNmE2N2Q3MzRjODg4YWUzZDI0YzEyYjQwMWMxIiwidXNlcl9pZCI6MywidXNlcm5hbWUiOiJcdTRlOGVcdTZkMGIifQ.0fa2HIGeDupbqD5f6Ed26Le7wD5dEjG-GCZm0-Ap-F8"# 目录包含要上传的.mp4文件
source_directory = r"D:\tjjg_videos"# 遍历目录,上传所有.mp4文件
for root, _, files in os.walk(source_directory):for filename in files:if filename.lower().endswith('.mp4'):file_path = os.path.join(root, filename)# 最多尝试上传三次max_retries = 3retries = 0while retries < max_retries:# 以二进制方式打开文件with open(file_path, 'rb') as file:# 准备请求参数# 构建请求参数payload = {'file': (filename, open(file_path, 'rb')),'resouce': (None, 'video'),}# 设置请求头,包括 Authorizationheaders = {'Authorization': f'{token}'}# 发送POST请求上传文件response = requests.post(upload_url, files=payload, headers=headers)# 检查响应状态码if response.status_code == 200:print(f"成功上传文件: {filename}")print(response.text)breakelse:print(f"上传文件失败: {filename}")print(response.text)retries += 1if retries < max_retries:print(f"重试上传文件: {filename} (第 {retries} 次)")time.sleep(2) # 等待2秒后重试else:print(f"上传文件失败超过最大重试次数: {filename}")print("上传完成")
del_mp4.py
批量删除垃圾数据
import asyncio
import aiohttp# 目标URL
base_url = "https://xxxx.xxxxxx.com/xp/api/v1/resource/"# 认证 token
token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoiYWNjZXNzIiwiZXhwIjoxNjk2Mzk5ODAwLCJpYXQiOjE2OTM4MDc4MDAsImp0aSI6IjJmZmZiNmE2N2Q3MzRjODg4YWUzZDI0YzEyYjQwMWMxIiwidXNlcl9pZCI6MywidXNlcm5hbWUiOiJcdTRlOGVcdTZkMGIifQ.0fa2HIGeDupbqD5f6Ed26Le7wD5dEjG-GCZm0-Ap-F8"# 构建要删除的ID范围
start_id = 602
end_id = 2121# 发送DELETE请求删除资源
async def delete_resource(session, resource_id):url = f"{base_url}{resource_id}/"headers = {'Authorization': f'{token}'}async with session.delete(url, headers=headers) as response:if response.status == 204:print(f"成功删除资源: {url}")else:print(f"删除资源失败: {url}")print(await response.text())# 异步删除资源
async def delete_resources():async with aiohttp.ClientSession() as session:tasks = [delete_resource(session, resource_id) for resource_id in range(start_id, end_id + 1)]await asyncio.gather(*tasks)# 执行异步删除操作
if __name__ == "__main__":loop = asyncio.get_event_loop()loop.run_until_complete(delete_resources())loop.close()print("删除完成")
相关文章:
Python脚本
update_format.py 批量转视频格式,超级慢,没什么卵用 import os import asyncio import subprocess import concurrent.futures import tracemalloctracemalloc.start()# 创建日志文件 log_file open(conversion_log.txt, w)async def convert_mkv_t…...
Kotlin的遍历方法
for循环 在下面代码中1…10表示的是1到10,两边都是闭包,输出12345678910 for (i in 1..10) println(i)加上花括号也支持 for (i: Int in 1..10) {println(i)}另外,当对整数进行for循环时,Kotlin还提供了一个step函数来定义迭代的…...
AskIt: Unified Programming Interface for Programming with Large Language Models
本文是LLM系列文章,针对《AskIt: Unified Programming Interface for Programming with Large Language Models》的翻译。 AskIt:用于大型语言模型编程的统一编程接口 摘要1 引言2 动机例子3 设计与实现4 实验评估5 相关工作6 结论 摘要 在不断发展的软…...
【wireshark抓取数据包-PGSQL协议】
测试查看PGSQL协议的网络流量数据明细 1)捕获过滤的条件设置,tcp.port5432(数据库的端口) 2)上面是wireshark的主窗口,分三大主块:Packlist List(数据包列表)…...
【idea学习】
1.debug: 文章详解 2.导入SpringBoot项目 文章详情...
ZooKeeper数据模型/znode节点深入
1、Znode的数据模型 1.1 Znode是什么? Znode维护了一个stat结构,这个stat包含数据变化的版本号、访问控制列表变化、还有时间戳。版本号和时间戳一起,可让Zookeeper验证缓存和协调更新。每次znode的数据发生了变化,版本号就增加。…...
容器编排工具的比较:Kubernetes、Docker Swarm、Nomad
随着容器化技术的普及,容器编排工具成为了现代应用部署和管理的重要组成部分。容器编排工具能够自动化容器的部署、扩展和管理,从而提高应用的可靠性和可伸缩性。在众多的容器编排工具中,Kubernetes、Docker Swarm和Nomad是三个备受关注的主要…...
nginx--技术文档--架构体系--底层核心-原理
Nginx的架构体系可以概括为“一个核心、两个模型。” “一个核心”指Nginx的核心功能,即HTTP请求处理。Nginx作为一个高性能的Web服务器,其核心功能是处理HTTP请求,包括接收请求、解析请求、处理请求和返回响应等。 “两个模型”指Nginx的多…...
Java23种设计模式之【单例模式】
目录 一.单例模式的起源,和应用场景 1.单例模式的前世今生! 2.什么是单例模式? 2.1使用单例模式的注意事项 2.2如何理解单例模式? 2.3单例模式的优势以及不足! 2.4使用场景 二.实现 1.实现思路 1.1创建一个 S…...
SQLserver基础入门理论(超基础)二
♥️作者:小刘在C站 ♥️个人主页: 小刘主页 ♥️努力不一定有回报,但一定会有收获加油!一起努力,共赴美好人生! ♥️学习两年总结出的运维经验,以及思科模拟器全套网络实验教程。专栏…...
macbookpro怎么删除软件没有鼠标
macbookpro怎么删除软件没有鼠标,macbookpro触摸板可以替代鼠标进行操作。左右键功能与鼠标相同,可用于执行删除操作。此外,还可以利用键盘上的Delete键来删除选中的文件。 删除软件方法 方法1、打开应用程序,键盘按住control,加点…...
华为数通方向HCIP-DataCom H12-821题库(单选题:241-260)
第241题 LS Request报文不包括以下哪一字段? A、通告路由器(Advertising Router) B、链路状态 ID (Link Srate ID) C、数据库描述序列号(Database Dascription Sequence lumber) D、链路状态类型 Link state type) 答案:C 解析: LS Request 报文中包括以下字段…...
PHP8内置函数中的变量函数-PHP8知识详解
在php8中,与变量相关的内置函数比较多,本文说一些比较重要的、常见的内置函数。今日着重讲解了5个,分别是:检测变量是否为空的函数empty()、判断变量是否定义过的函数isset()、销毁指定的变量的函数unset()、获取变量的类型的函数…...
9月3日,每日信息差
第一、中国中铁与广州市城中村改造做地主体签署战略合作框架协议。根据协议,双方将积极响应广州市统筹做地推进高质量发展工作精神,充分发挥双方优势资源,共同加大在物业复建安置、基础设施建设、综合开发投资、城中村改造(微改造…...
2023年了,java后端还有未来吗?
前言 Java当下确实是比较的内卷,但关键在于个人,可以看看不同地方(这里主要举例北上广深一线城市)对于Java开发工程师这个职位的具体要求: 在以下北上广深这些一线大城市的面试招聘当中不难看出,凡是工资…...
使用cmake,将github上的某一个库进行集成到vs2022上
可以参考如下链接的内容: (还未完成,将在后序补充) 1.首先使用cmake,得到对应库的lib,include,bin文件夹 可以参考 https://www.youtube.com/watch?vu5-Df1YlxCI 2.现在我用cmake对这个第三方库进行编译,生成了三个文件夹:一个放的是lib文件(lib文件…...
第二张微服务的调用与注册
文章目录 工程导入利用RestTemplate调用服务需求创建RestTemplate的实例到Spring容器使用RestTemplate发送请求消费者和提供者 Eureka注册中心服务远程调用会出现的问题Eureka的结构和作用Eureka的配置过程搭建注册中心服务注册服务发现 Ribbon负载均衡负载均衡原理源码跟踪总结…...
iWatch框架设计
iWatch框架设计 一、项目框架结构设计 1、项目文件介绍 OverSeaProject:是IOS相关文件文件内容iWatchApp和iWatch Extension:是之前使用xcode14之前的xcode创建的360 app的Watch App,产生的文件结构,包含一个app和Extension的ta…...
【python】读取.dat格式文件
import binascii# 打开二进制文件以只读二进制模式 with open(EXCEL/文件.dat, rb) as file:binary_data file.read()print(binary_data)# 将二进制数据转换为十六进制字符串 hex_data binascii.hexlify(binary_data).decode(utf-8) # binary_data 现在包含了文件的二进制内容…...
机器学习课后习题 --- 朴素贝叶斯
(一)单选题 1.假设会开车的本科生比例是15%,会开车的研究生比例是23%。若在某大学研究生占学生比例是20%,则会开车的学生是研究生的概率是多少? A:80%B:16.6% C:23% D:15% 2.下列关于朴素贝叶斯的特点说法错误的是…...
碧蓝航线全皮肤解锁终极指南:Perseus补丁五分钟快速上手
碧蓝航线全皮肤解锁终极指南:Perseus补丁五分钟快速上手 【免费下载链接】Perseus Azur Lane scripts patcher. 项目地址: https://gitcode.com/gh_mirrors/pers/Perseus 还在为碧蓝航线中那些精美的舰娘皮肤需要付费解锁而烦恼吗?想要免费体验所…...
八股整理之JVM篇
JVM的内存模型介绍一下根据 JDK 8 规范,JVM 运行时内存共分为虚拟机栈、堆、元空间、程序计数器、本地方法栈五个部分。还有一部分内存叫直接内存,属于操作系统的本地内存,也是可以直接操作的。JVM的内存结构主要分为以下几个部分:…...
BarrageGrab:如何构建企业级跨平台直播数据采集系统?
BarrageGrab:如何构建企业级跨平台直播数据采集系统? 【免费下载链接】BarrageGrab 抖音快手bilibili直播弹幕wss直连,非系统代理方式,无需多开浏览器窗口 项目地址: https://gitcode.com/gh_mirrors/ba/BarrageGrab 在直播…...
N_m3u8DL-CLI-SimpleG:一键下载M3U8视频的终极图形界面工具
N_m3u8DL-CLI-SimpleG:一键下载M3U8视频的终极图形界面工具 【免费下载链接】N_m3u8DL-CLI-SimpleG N_m3u8DL-CLIs simple GUI 项目地址: https://gitcode.com/gh_mirrors/nm3/N_m3u8DL-CLI-SimpleG 你是否曾经想要保存在线视频却因为复杂的M3U8格式而束手无…...
Sixpack Redis数据存储策略:高效管理A/B测试数据的10个技巧
Sixpack Redis数据存储策略:高效管理A/B测试数据的10个技巧 【免费下载链接】sixpack Sixpack is a language-agnostic a/b-testing framework 项目地址: https://gitcode.com/gh_mirrors/si/sixpack Sixpack是一个语言无关的A/B测试框架,它通过R…...
Tonzhon音乐:纯净无干扰的现代音乐播放平台终极指南
Tonzhon音乐:纯净无干扰的现代音乐播放平台终极指南 【免费下载链接】tonzhon-music 铜钟 Tonzhon (tonzhon.whamon.com): 干净纯粹的音乐平台 (铜钟已不再使用 tonzhon.com,现在的 tonzhon.com 不是正版的铜钟) 项目地址: https://gitcode.com/GitHub…...
SpringBoot+Vue体育赛事志愿者管理系统源码+论文
代码可以查看文章末尾⬇️联系方式获取,记得注明来意哦~🌹 分享万套开题报告任务书答辩PPT模板 作者完整代码目录供你选择: 《SpringBoot网站项目》1800套 《SSM网站项目》1500套 《小程序项目》1600套 《APP项目》1500套 《Python网站项目》…...
Amphenol ICC线束MSPEC6P2A5010应用与替代分析
随着工业通信、车载网络以及高速数据互联的发展,越来越多设备开始采用高性能线束组件来保证数据稳定传输。在工业自动化与智能设备领域,Amphenol ICC推出的MSPE系列近年来关注度持续提升,其中MSPEC6P2A5010就是比较典型的一款工业级线束组件。…...
RISC-V架构:gp寄存器与链接器松弛
目录 0 相关内容 1 gp(global pointer)全局指针寄存器 1. gp 寄存器的核心作用:高效访问全局数据 2. 为什么 Cortex-M 没有 gp? 3. gp 寄存器在 FreeRTOS 中的作用 2 链接器松弛 3 如何将全局小变量连接到 .sdata 段并设置 …...
leetcode思路-236 二叉树的最近公共祖先
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的…...
