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

python文本合并脚本

做数据集本地化时,用到了文本txt合并问题,用了trae -cn ai辅助测试一下效果,还可以吧,但还是不如人灵光,反复的小错,如果与对成手,应该很简单,这里只做了测试吧,南无阿弥陀佛。哈哈。
在这里插入图片描述
开发的独立程序,合并过程如下图:
在这里插入图片描述
源码如下:

import os
import argparse
import concurrent.futures
import zipfile
import tkinter as tk
from tkinter import filedialog
from tkinter import ttk  # 导入 ttk 模块
from bs4 import BeautifulSoup  # 导入 bs4 模块
from html.parser import HTMLParser
import configparser
# 在文件头部添加sys模块导入
import sys
# 在文件头部添加缺失的模块导入
import re  # 添加正则模块导入class MyHTMLParser(HTMLParser):def __init__(self):super().__init__()self.text = ""def handle_data(self, data):self.text += datadef process_file(file_path, output_file):encodings = ['utf-8-sig', 'gb18030', 'big5']  # 修改编码优先级last_error = Nonefor encoding in encodings:try:with open(file_path, 'r', encoding=encoding, errors='strict') as infile:  # 使用严格模式if file_path.endswith(('.html', '.htm')):content = BeautifulSoup(infile, 'html.parser').get_text()else:content = infile.read()lines = content.splitlines()non_empty_lines = [line for line in lines if line.strip()]cleaned_content = '\n'.join(non_empty_lines) + '\n'try:with open(output_file, 'a', encoding='utf-8-sig') as outfile:  # 使用带BOM的UTF-8if cleaned_content:outfile.write(cleaned_content)print(f"成功写入文件: {file_path} (编码: {encoding})")  # 添加编码信息return True, Noneelse:return False, Exception("清理后内容为空")except Exception as e:print(f"写入文件失败: {str(e)}")return False, eexcept UnicodeDecodeError as e:last_error = econtinuereturn False, last_error or Exception(f"所有编码尝试失败: {str(last_error)}")def merge_txt_files(input_folder, output_file, progress, root, listbox, total_files_label, current_file_label, max_files=None):try:# 确保输出目录存在os.makedirs(os.path.dirname(output_file), exist_ok=True)# 确保输出文件存在且为空with open(output_file, 'w', encoding='utf-8') as f:f.write('')except Exception as e:listbox.insert(tk.END, f"无法初始化输出文件: {str(e)}")returntxt_files = []for root_dir, _, files in os.walk(input_folder):for file in files:if file.endswith(('.txt', '.html', '.htm')):txt_files.append(os.path.join(root_dir, file))elif file.endswith('.zip'):# 保留zip处理逻辑但简化passif max_files and str(max_files).isdigit():txt_files = txt_files[:int(max_files)]total_files = len(txt_files)if total_files_label:total_files_label.config(text=f"文件总数: {total_files}")for i, file_path in enumerate(txt_files):listbox.insert(tk.END, f"处理中: {file_path}")success, error = process_file(file_path, output_file)if not success:listbox.insert(tk.END, f"处理失败: {file_path}")if error:listbox.insert(tk.END, f"错误详情: {str(error)}")listbox.itemconfig(tk.END, {'fg':'red'})  # 设置错误信息为红色continueif current_file_label:current_file_label.config(text=f"当前进度: {i+1}/{total_files}")if progress:progress['value'] = ((i+1) / total_files) * 100root.update_idletasks()# 删除以下两个函数
def read_history_paths():config = configparser.ConfigParser()config.read('history_paths.ini')input_folder = ""output_file = ""if 'Paths' in config:input_folder = config['Paths'].get('input_folder', '')output_file = config['Paths'].get('output_file', '')return input_folder, output_filedef save_history_paths(input_folder, output_file):config = configparser.ConfigParser()config['Paths'] = {'input_folder': input_folder,'output_file': output_file}with open('history_paths.ini', 'w') as configfile:config.write(configfile)def run_merge():# 获取新路径input_folder = input_folder_entry.get()output_file = output_file_entry.get()max_files = max_files_entry.get()print(f"输入文件夹路径: {input_folder}")print(f"输出文件路径: {output_file}")if input_folder:def update_file_count():input_folder = input_folder_entry.get()if input_folder and os.path.isdir(input_folder):txt_files = []for root_dir, _, files in os.walk(input_folder):for file in files:if file.endswith(('.txt', '.html', '.htm')):txt_files.append(os.path.join(root_dir, file))max_files_entry.delete(0, tk.END)max_files_entry.insert(0, str(len(txt_files)))if input_folder and output_file:# 自动创建输出目录os.makedirs(os.path.dirname(output_file), exist_ok=True)# 路径权限验证if not os.access(os.path.dirname(output_file), os.W_OK):status_label.config(text=f"输出路径不可写: {os.path.dirname(output_file)}")return# 初始化UI组件file_process_listbox.delete(0, tk.END)progress_bar['value'] = 0# 状态标签(添加在进度条下方)status_label = tk.Label(root, text="准备就绪", fg="blue")status_label.grid(row=5, column=0, columnspan=3, pady=5, sticky='ew')# 文件统计标签(添加在状态标签下方)total_files_label = tk.Label(root, text="文件总数: 0")total_files_label.grid(row=6, column=0, padx=5, sticky='e')current_file_label = tk.Label(root, text="当前完成文件数: 0/0")current_file_label.grid(row=6, column=1, padx=5, sticky='w')# 添加滚动条scrollbar = tk.Scrollbar(root)scrollbar.grid(row=4, column=3, sticky='ns')file_process_listbox.config(yscrollcommand=scrollbar.set)scrollbar.config(command=file_process_listbox.yview)# 设置统一字体root.option_add("*Font", "微软雅黑 10")# 调用合并函数merge_txt_files(input_folder, output_file,progress_bar,root,file_process_listbox,total_files_label,current_file_label,max_files)# 保存新的历史路径# 删除以下保存历史路径的代码# save_history_paths(input_folder, output_file)# 确保在文件处理完成后更新状态栏文字status_label.config(text=f"已将 {input_folder} 中的文件合并到 {output_file}")# 移除多余的状态更新代码# if input_folder and output_file:#     status_label.config(text=f"已将 {input_folder} 中的文件合并到 {output_file}")def extract_zip(zip_file_path, temp_dir):try:with zipfile.ZipFile(zip_file_path, 'r') as zip_ref:zip_ref.extractall(temp_dir)except Exception as e:print(f"解压文件 {zip_file_path} 时出错: {e}")  # 已有日志输出,可保留或添加更多细节# 运行主循环
# 在main模块添加完整的GUI初始化代码
if __name__ == "__main__":root = tk.Tk()root.title("TXT 文件合并工具")root.geometry("800x600")# 输入文件夹组件tk.Label(root, text="输入文件夹:").grid(row=0, column=0, padx=5, pady=5)input_folder_entry = tk.Entry(root, width=50)input_folder_entry.grid(row=0, column=1, padx=5, pady=5)# 输出文件组件 tk.Label(root, text="输出文件:").grid(row=1, column=0, padx=5, pady=5)output_file_entry = tk.Entry(root, width=50)output_file_entry.grid(row=1, column=1, padx=5, pady=5)# 移除这行有问题的代码# output_file_entry.insert(0, output_file_history)  # 填充历史路径# 修改输入文件夹浏览按钮tk.Button(root, text="浏览", command=lambda: [input_folder_entry.delete(0, tk.END),input_folder_entry.insert(0, filedialog.askdirectory()),update_file_count()  # 添加自动更新文件数量功能]).grid(row=0, column=2, padx=5)tk.Button(root, text="浏览", command=lambda: [output_file_entry.delete(0, tk.END),output_file_entry.insert(0, filedialog.asksaveasfilename())]).grid(row=1, column=2, padx=5)# 最大文件数限制# 最大文件数限制tk.Label(root, text="最大合并文件数:").grid(row=2, column=0, padx=5, pady=5)max_files_entry = tk.Entry(root, width=50)max_files_entry.insert(0, "10000")  # 设置默认值为10000max_files_entry.grid(row=2, column=1, padx=5, pady=5)# 进度条和执行按钮progress_bar = ttk.Progressbar(root, orient="horizontal", length=400, mode="determinate")progress_bar.grid(row=3, column=0, columnspan=2, pady=10, sticky='ew')run_button = tk.Button(root, text="开始合并", command=run_merge, bg="#4CAF50", fg="white")run_button.grid(row=3, column=2, padx=10, pady=10, sticky='ew')# 文件处理列表file_process_listbox = tk.Listbox(root, width=100, height=20)file_process_listbox.grid(row=4, column=0, columnspan=3, padx=10, pady=10, sticky="nsew")# 状态标签和统计信息status_label = tk.Label(root, text="准备就绪", fg="blue")status_label.grid(row=5, column=0, columnspan=3, pady=5, sticky='ew')# 配置布局权重# 确保有正确的布局权重设置root.columnconfigure(1, weight=1)  # 使中间列可扩展root.rowconfigure(4, weight=1)   # 使列表区域可扩展if len(sys.argv) > 1:parser = argparse.ArgumentParser()parser.add_argument('input_folder')parser.add_argument('output_file')args = parser.parse_args()merge_txt_files(args.input_folder, args.output_file, None, None, None, None, None)else:# 确保所有布局代码在 mainloop 之前root.mainloop()

南无阿弥陀佛,哈哈。

相关文章:

python文本合并脚本

做数据集本地化时,用到了文本txt合并问题,用了trae -cn ai辅助测试一下效果,还可以吧,但还是不如人灵光,反复的小错,如果与对成手,应该很简单,这里只做了测试吧,南无阿弥…...

Coding Practice,48天强训(25)

Topic 1&#xff1a;笨小猴(质数判断的几种优化方式&#xff0c;容器使用的取舍&#xff09; 笨小猴__牛客网 #include <bits/stdc.h> using namespace std;bool isPrime(int n) {if(n < 1) return false;if(n < 3) return true; // 2和3是质数if(n % 2 0 …...

pytorch学习使用

1. 基础使用 1.1 基础信息 # 输出 torch 版本 print(torch.__version__)# 判断 cuda 是否可用 print(torch.cuda.is_available()) """ 2.7.0 False """1.2 创建tensor # 创建一个5*3的矩阵&#xff0c;初始值为0. print("-------- empty…...

《AI大模型应知应会100篇》第38篇:大模型与知识图谱结合的应用模式

第38篇&#xff1a;大模型与知识图谱结合的应用模式 摘要 随着大模型&#xff08;如GPT、BERT等&#xff09;和知识图谱技术的快速发展&#xff0c;两者的融合为构建更精准、可解释的智能系统提供了新的可能性。本文将深入探讨大模型与知识图谱的能力互补性、融合架构设计以及…...

TypeScript中的type

在 TypeScript 中&#xff0c;type 是一个非常重要的关键字&#xff0c;用于定义类型别名&#xff08;Type Alias&#xff09;。它允许你为一个类型创建一个新的名字&#xff0c;从而使代码更加简洁和可读。type 可以用来定义基本类型、联合类型、元组类型、对象类型等。以下是…...

数据库3,

describe dt drop table 删表 df delete from删行 usw update set where更新元素 iiv insert into values&#xff08;&#xff09;插入行 sf select from选行 select *选出所有行 &#xff08;ob order by 排序 由低到高 DESC由高到低 order by score&#…...

I-CON: A Unifying Framework for Representation Learning

1&#xff0c;本文关键词 I-Con框架、表征学习、KL散度、无监督分类、对比学习、聚类、降维、信息几何、监督学习、自监督学习、统一框架 2&#xff0c;术语表 术语解释I-Con本文提出的统一表征学习方法&#xff0c;全称Information Contrastive Learning&#xff0c;通过最…...

mybatis首个创建相关步骤

1。先关联数据库&#xff0c;用户&#xff0c;密码&#xff0c;数据库保持一致 2.添加包和类 1.User放和数据库属性一样的 package com.it.springbootmybatis01.pojo;lombok.Data lombok.AllArgsConstructor lombok.NoArgsConstructor public class User {private Integer i…...

vue3子传父——v-model辅助值传递

title: 子组件向父组件传值 date: 2025-04-27 19:11:09 tags: vue3 vue3子传父——v-model辅助值传递 一、子组件发出 1.步骤一创建emit对象 这个对象使用的是defineEmits进行的创建&#xff0c;emit的中文意思又叫发出&#xff0c;你就把他当成一个发出数据的函数方法来用…...

Golang | 向倒排索引上添加删除文档

syntax "proto3";package types;message Keyword {string Field 1; // 属性/类型/名称string Word 2; // 关键词 }message Document {string Id 1; //业务使用的唯一Id&#xff0c;索引上此Id不会重复uint64 IntId 2; //倒排索引上使用的文档id(业务侧不用管这…...

秒杀系统 Kafka 架构进阶优化

文章目录 前言1. Kafka Topic 分区&#xff08;Partition&#xff09;设计2. Kafka 消费者高可用部署&#xff08;Consumer Scaling&#xff09;3. Kafka Redis 多级限流降级设计4. 秒杀链路全链路追踪&#xff08;Tracing&#xff09;5. Kafka 死信队列&#xff08;DLQ&#…...

探索大语言模型(LLM):自监督学习——从数据内在规律中解锁AI的“自学”密码

文章目录 自监督学习&#xff1a;从数据内在规律中解锁AI的“自学”密码一、自监督学习的技术内核&#xff1a;用数据“自问自答”1. 语言建模&#xff1a;预测下一个单词2. 掩码语言模型&#xff08;MLM&#xff09;&#xff1a;填补文本空缺3. 句子顺序预测&#xff08;SOP&a…...

Java自定义注解详解

文章目录 一、注解基础注解的作用Java内置注解二、元注解@Retention@Target@Documented@Inherited@Repeatable(Java 8)三、创建自定义注解基本语法注解属性使用自定义注解四、注解的处理方式1. 编译时处理2. 运行时处理(反射)五、实际应用场景1. 依赖注入框架2. 单元测试框…...

在使用docker创建容器运行报错no main manifest attribute, in app.jar

原因就是在打包的时候pom配置有问题,重新配置再打包 我的dockerfile FROM openjdk:11 MAINTAINER yyf COPY *.jar /app.jar EXPOSE 8082 ENTRYPOINT ["java","-jar","app.jar"] 修改过后&#xff0c;经测试成功了 参考我的pom <?xml ver…...

C#中属性和字段的区别

在C# 中属性和字段的区别 在 C# 中&#xff0c;字段(field)和属性(property)都是用于存储数据的成员&#xff0c;但它们有重要的区别&#xff1a; 主要区别 1. 访问控制 - 字段&#xff1a;直接存储数据的变量 - 属性&#xff1a;通过访问器(get/set)控制对私有字段的…...

分析型数据库入门指南:如何选择适合你的实时分析工具?

一、什么是分析型数据库&#xff1f;为什么需要它&#xff1f; 据Gartner最新报告显示&#xff0c;超过75%的企业现已在关键业务部门部署了专门的分析型数据库&#xff0c;这一比例还在持续增长。 随着数据量呈指数级增长&#xff0c;传统数据库已无法满足复杂分析场景的需求…...

第三方软件检测报告:热门办公软件评估及功能表现如何?

第三方软件检测报告是重要文件。它用于对软件做专业评估。能反映软件各项性能。能反映软件安全性等指标。该报告为软件使用者提供客观参考。该报告为软件开发者提供客观参考。有助于发现问题。还能推动软件改进。 检测概述 本次检测针对一款热门办公软件。采用了多种先进技术…...

GPUStack昇腾Atlas300I duo部署模型DeepSeek-R1【GPUStack实战篇2】

2025年4月25日GPUStack发布了v0.6版本&#xff0c;为昇腾芯片910B&#xff08;1-4&#xff09;和310P3内置了MinIE推理&#xff0c;新增了310P芯片的支持&#xff0c;很感兴趣&#xff0c;所以我马上来捣鼓玩玩看哈 官方文档&#xff1a;https://docs.gpustack.ai/latest/insta…...

2025年邵阳市工程技术研究中心申报流程、条件、奖补

一、邵阳市工程技术研究中心申报条件 &#xff08;一&#xff09;工程技术研究中心主要依托科技型企业组建&#xff0c;依托单位应具有以下条件&#xff1a; 1. 具有较强技术创新意识的领导班子和技术水平高、工程化实践经验丰富的工程技术研发队伍&#xff0c;其中固定人员…...

【Python】Matplotlib:立体永生花绘制

本文代码部分实现参考自CSDN博客&#xff1a;https://blog.csdn.net/ak_bingbing/article/details/135852038 一、引言 Matplotlib作为Python生态中最著名的可视化库&#xff0c;其三维绘图功能可以创造出令人惊叹的数学艺术。本文将通过一个独特的参数方程&#xff0c;结合极…...

Spark Streaming核心编程总结(四)

一、有状态转化操作&#xff1a;UpdateStateByKey 概念与作用 UpdateStateByKey 用于在流式计算中跨批次维护状态&#xff08;如累加统计词频&#xff09;。它允许基于键值对形式的DStream&#xff0c;通过自定义状态更新函数&#xff0c;将历史状态与新数据结合&#xff0c;生…...

虚拟数字人:从虚拟到现实的跨越与未来展望

在人工智能和数字技术飞速发展的今天&#xff0c;虚拟数字人&#xff08;Digital Humans&#xff09;正逐渐从科幻走向现实&#xff0c;成为科技领域的新焦点。虚拟数字人不仅在娱乐、教育、客服等领域展现出巨大的应用潜力&#xff0c;还在不断推动着人机交互方式的变革。本文…...

RuoYi-Vue项目Docker镜像构建、推送与部署完整流程

RuoYi-Vue项目Docker镜像构建、推送与部署流程 一、本地构建镜像 1. 使用docker-compose构建镜像 基于docker-compose.yml文件&#xff0c;可以一次构建所有服务镜像&#xff1a; # 构建所有服务 docker-compose build# 或者构建并启动 docker-compose up -d --build若只需…...

MyBatis DTD [Element type “if“ must be declared]

MyBatis DTD [Element type "if" must be declared] <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"&g…...

【项目实训个人博客】multi-agent调研(1)

随着LLM的涌现&#xff0c;以LLM为中枢构建的Agent系统在近期受到了广泛的关注。Agent系统旨在利用LLM的归纳推理能力&#xff0c;通过为不同的Agent分配角色与任务信息&#xff0c;并配备相应的工具插件&#xff0c;从而完成复杂的任务。 目前更常见的框架大多聚焦于single-ag…...

OpenSSH配置连接远程服务器MS ODBC驱动与Navicat数据库管理

OpenSSH配置连接远程服务器MS ODBC驱动与Navicat数据库管理 目录 OpenSSH配置连接远程服务器MS ODBC驱动与Navicat数据库管理 一、MS ODBC驱动 1.1、安装到Windows后的表现形式 1.2、版本的互斥性 1.3、安装程序 1.4、配置后才可用 二、Navicat数据库管理工具 2.1、安…...

Day14(链表)——LeetCode234.回文链表141.环形链表

1前言 这几天脑子真转不动&#xff0c;本想刷点简单题养养脑子&#xff0c;结果发现简单题也想不到&#xff0c;只是看答案好理解了。。。 2 LeetCode234.回文链表(LeetCode234) 2.1 题目描述 即判断链表是否为回文链表&#xff0c;回文链表即链表的数值正向遍历与反向遍历结…...

Centos 7.6安装redis-6.2.6

1. 安装依赖 确保系统已经安装了必要的编译工具和库&#xff1a; sudo yum groupinstall "Development Tools" -y sudo yum install gcc make tcl -y 2. 解压 Redis 源码包 进入 /usr/local/ 目录并解压 redis-6.2.6.tar.gz 文件&#xff1a; cd /usr/local/ sudo ta…...

react的 Fiber 节点的链表存储

在React Fiber架构中&#xff0c;Fiber节点的链表存储是一种重要的数据结构组织方式&#xff0c;用于管理和遍历Fiber节点。以下是关于Fiber节点链表存储的详细介绍&#xff1a; 链表结构 单链表&#xff1a;React Fiber节点通过next指针形成单链表结构。每个Fiber节点都有一…...

MCU ADC参考电压变化怎么办?

在嵌入式系统设计中&#xff0c;ADC&#xff08;模数转换器&#xff09;精度直接决定了系统对模拟信号的感知能力。 然而&#xff0c;很多工程师对ADC参考电压&#xff08;VREF&#xff09;的认识仍然存在模糊&#xff0c;尤其是在电池供电、电压不稳场景下。 ADC参考电压定义…...

IP地址与子网计算工具

IP地址与子网计算工具 工具介绍 这是一个免费的在线IP地址与子网计算工具&#xff0c;专为网络工程师和IT维护人员设计。只需输入IPv4地址和子网掩码位数&#xff0c;即可快速计算出&#xff1a; 工具已发布在: http://mutou888.com/tools/net/ip/index.html 网络地址广播地…...

显卡驱动与cuda toolkit版本对应关系

查显卡对应驱动的网址&#xff1a; NVIDIA GeForce 驱动程序 - N 卡驱动 | NVIDIA 查这个的时候&#xff0c;不同的显卡对应不同的产品类型和系列&#xff0c;需要先选对这两个&#xff0c;才能找到对应的产品名称&#xff0c;比如A6000&#xff0c;是在RTX/Quadro类型&#xf…...

典籍查询界面增加我的收藏查询功能

1.效果展示 点击我的收藏后可以显示当前用户收藏的典籍 2.后端代码 3.前端代码...

浮点数:IEEE 754标准

IEEE 754 标准是一种由电气和电子工程师协会&#xff08;IEEE&#xff09;制定的浮点数表示的标准&#xff0c;广泛应用于计算机系统中&#xff0c;下面是详细介绍&#xff1a; 历史背景 在 IEEE 754 标准出现之前&#xff0c;不同的计算机系统采用各自的浮点数表示方法&…...

‌RISC-V架构的低功耗MCU多电压域优化设计

RISC-V核低功耗MCU的多电压域设计是一种优化电源管理以降低功耗的技术方案。该设计通过电源域划分、电压转换和时序管理等手段&#xff0c;有效降低了系统功耗并提升能效&#xff0c;适用于物联网和嵌入式系统等场景。 多电压域设计的基本原理是将芯片划分为多个独立供电区域&…...

【密码学——基础理论与应用】李子臣编著 第八章 SM2公钥密码算法 课后习题

免责声明 这里都是自己搓或者手写的。 里面不少题目感觉有问题或者我的理解有偏颇&#xff0c;请大佬批评指正&#xff01; 不带思考抄作业的请自动退出&#xff0c;我的并非全对&#xff0c;仅仅提供思维&#xff01; 题目 逐题解析 知识前提&#xff1a;模运算的分数怎么转…...

在winform中使用chromiumWebBrowser显示Echarts图表

首先&#xff0c;在项目引用中添加CefSharp&#xff0c;这个是谷歌的控件。 然后在form中添加一个chromiumWebBrower控件 在form初始化时&#xff0c;执行浏览器组件的初始化 //浏览器组件只初始化一次&#xff0c;所以放在主界面 CefSettings settings new CefSettings(); …...

基于ART光学跟踪系统打造具有开创性的人车互动VR解决方案

随着汽车行业的日益发展更多的车内内容量和更高的客户体验使得车辆越来越复杂复杂&#xff0c;。此外消费者的可持续意识与政府的限制&#xff0c;也迫使企业在整个生产过程中提高资源利用率。与此同时为保证利润&#xff0c;开发时间进一步缩短&#xff0c;预算也随之减少。 由…...

面试记录1-春招补录0427

快手面试记录&#xff1a; 面试官是个帅哥&#xff0c;嘿嘿&#xff0c;而且感觉很厉害的样子&#xff0c;说话也比较温柔。 最近同时面试了好几家公司&#xff0c;感觉面试官的水平差距还是比较明显的。快手这位面试官给我的印象很不错哇&#xff01; 一听他说话就知道他很厉害…...

【计算机网络性能优化】从基础理论到实战调优

目录 前言技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键技术模块说明技术选型对比 二、实战演示环境配置要求核心代码实现案例1&#xff1a;iPerf3带宽测试案例2&#xff1a;TCP窗口优化案例3&#xff1a;QoS流量整形 运行…...

Maven下载aspose依赖失败的解决方法

Maven下载aspose依赖失败的解决方法 日期&#xff1a;2025年4月27日 遇到问题&#xff1a; Could not find artifact com.aspose:aspose-cad:pom:23.9 in aliyunmaven (https://maven.aliyun.com/repository/public) [WARNING] The POM for com.aspose:aspose-cad:jar:23.9 is…...

Redis的阻塞

Redis的阻塞 Redis的阻塞问题主要分为内在原因和外在原因两大类&#xff0c;以下从这两个维度展开分析&#xff1a; 一、内在原因 1. 不合理使用API或数据结构 Redis 慢查询 Redis 慢查询的界定 定义&#xff1a;Redis 慢查询指命令执行时间超过预设阈值&#xff08;默认 10m…...

OkHttp源码梳理

目录 一、基本使用 1 创建 OkHttpClient 2 构建请求 Request 3 创建和执行 Call 二、OkHttp请求整体流程 1. 用户调用入口 2. RealCall执行逻辑 2.1 同步请求&#xff1a;RealCall.execute() 2.2 异步请求&#xff1a;RealCall.enqueue(Callback) 3. Dispatcher调度请…...

【第三十三周】BLIP论文阅读笔记

BLIP 摘要Abstract文章信息引言方法MED预训练CapFilt 关键代码实验结果总结 摘要 本博客介绍了BLIP&#xff08;Bootstrapping Language-Image Pre-training&#xff09;&#xff0c;这是一种创新的视觉-语言预训练框架&#xff0c;旨在通过统一模型架构和高效数据增强策略&am…...

如何配置osg编译使支持png图标加载显示

步骤如下&#xff1a; 1.下载osg代码 git clone https://github.com/openscenegraph/OpenSceneGraph.git cd OpenSceneGraph 2.开始配置编译 mkdir build cd build cmake … -DBUILD_OSG_PLUGINS_BY_DEFAULT1 -DBUILD_OSG_PLUGIN_PNG1 3.编译与安装 make make install 4.在安装…...

234. 回文链表(java)

个人理解&#xff1a; 1.先找到链表的中间节点&#xff0c;将链表分为前后两部分 方法&#xff1a;设置快慢指针&#xff0c;初始都指向头节点&#xff0c;慢指针每次走一步&#xff0c;快指针每次走两步。循环结束条件为&#xff1a;快指针后两个元素不为空&#xff0c;此时慢…...

面试:结构体默认是对齐的嘛?如何禁止对齐?

是的。 结构体默认是对齐的‌。结构体对齐是为了优化内存访问速度和减少CPU访问内存时的延迟。结构体对齐的规则如下&#xff1a; 某数据类型的变量存放的地址需要按有效对齐字节剩下的字节数可以被该数据类型所占字节数整除&#xff0c;char可以放在任意位置&#xff0c;int存…...

Leetcode837.新21点

目录 题目算法标签: 数学, 概率, 动态规划思路代码 题目 837. 新 21 点 算法标签: 数学, 概率, 动态规划 思路 定义状态表示为 f [ i ] f[i] f[i], 表示分数达到 i i i的时候的概率, 分析状态计算, 假设当前的分数是 i i i, 抽取到的牌得分数是 x x x, 那么当前状态就会转移…...

【C到Java的深度跃迁:从指针到对象,从过程到生态】第四模块·Java特性专精 —— 第十五章 泛型:类型系统的元编程革命

一、从C的void*到Java类型安全 1.1 C泛型的原始实现 C语言通过void*和宏模拟泛型&#xff0c;存在严重安全隐患&#xff1a; 典型泛型栈实现&#xff1a; #define DECLARE_STACK(type) \ struct stack_##type { \ type* data; \ int top; \ int capacity; \ }; #de…...

纯净无噪,智见未来——MAGI-1本地部署教程,自回归重塑数据本质

一、MAGI-1简介 MAGI-1 是一种逐块生成视频的自回归去噪模型&#xff0c;而非一次性生成完整视频。每个视频块&#xff08;含 24 帧&#xff09;通过整体去噪处理&#xff0c;当前块达到特定去噪阈值后&#xff0c;立即启动下一块的生成。这种流水线设计支持 最多 4 个块的并发…...