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

律所录音证据归集工具:基于PyQt6与多线程的自动化音频管理解决方案

在律所日常工作中,音频证据的整理与归集是一个高频且复杂的任务。面对大量的案件录音文件,如何实现快速且准确的分类与存档,成为了律所提高效率、降低出错率的关键。本文将通过技术角度解析一款名为律所录音证据归集工具的项目,详细介绍其背后的技术架构、实现细节以及如何通过自动化提升工作效率。

项目概述

该工具主要面向律师事务所,通过自动化手段帮助用户快速整理录音文件,生成规范化的目录结构,支持导入案件信息与音频文件,并根据案件数据自动匹配、命名及分类音频文件。工具基于PyQt6进行图形化界面开发,使用多线程技术避免长时间操作造成界面卡顿。

技术栈

  1. PyQt6:作为GUI框架,PyQt6提供了简洁易用的界面开发方式,能够快速创建交互式应用。
  2. 多线程:为了确保在大量数据处理时界面不会卡顿,我们使用了PyQt的QThreadQObject进行多线程任务的处理。
  3. Pandas:用于处理导入的Excel表格数据,解析案件信息并与音频文件进行匹配。
  4. 自定义模块:如daoru(导入模块)、sorting(音频排序模块)、export(导出模块)等,负责音频的整理、文件路径的管理以及最终的导出操作。

核心功能实现

1. 导入案件数据与音频文件

在程序的开始,用户需要导入案件信息和音频文件。我们使用了QFileDialog来弹出文件选择对话框,确保用户能够方便地导入相关文件。音频文件和Excel表格通过以下代码导入:

def on_import_audio_folder(self):
    folder = daoru.import_audio_folder(self, self.first_widget)
    if folder:
        self.audio_folder = folder

def on_import_excel(self):
    phone_list, df_data = daoru.import_phone_file_excel(self, self.first_widget)
    if phone_list is not None and df_data is not None:
        self.phone_list = phone_list
        self.excel_df = df_data
        # 打印导入的号码信息
        self.try_print_converted_phone_data()
 

通过调用daoru.import_audio_folderdaoru.import_phone_file_excel,我们分别导入了音频文件夹和案件信息表格。在on_import_excel方法中,Excel表格数据会被解析成Pandas DataFrame格式,便于后续的数据处理和分析。

2. 数据匹配与音频归集

音频文件与案件信息的匹配是核心功能之一。根据Excel中的案件数据(如电话号码、案件编号),我们会将音频文件重命名并按规则存档。以下是处理音频排序的代码实现:

class SortingWorker(QObject):
    finished = pyqtSignal()
    error = pyqtSignal(str)
    log_signal = pyqtSignal(str)
    progress_signal = pyqtSignal(int)

    def __init__(self, excel_data, audio_folder, output_base, org_code, ent_name):
        super().__init__()
        self.excel_data = excel_data
        self.audio_folder = audio_folder
        self.output_base = output_base
        self.org_code = org_code
        self.ent_name = ent_name

    def run(self):
        try:
            sorting.one_click_sort(
                excel_data=self.excel_data,
                audio_folder=self.audio_folder,
                output_base=self.output_base,
                org_code=self.org_code,
                ent_name=self.ent_name,
                log_callback=self.log_signal.emit,
                progress_callback=self.progress_signal.emit
            )
            self.finished.emit()
        except Exception as e:
            self.error.emit(str(e))
 

 

SortingWorker类负责执行音频文件的排序和归集工作,one_click_sort方法是排序的核心函数,接收案件数据、音频文件夹路径等参数,进行音频文件的命名和整理。在排序过程中,我们使用progress_signal信号来实时更新进度条。

3. 导出整理结果

整理完成后,用户可以选择导出整理好的音频文件及其路径。此过程不仅会生成整理的文本文件(记录文件路径),还会将音频文件复制到指定的目录中,便于后期的查找和存档。export.export_txt_and_copy负责将整理结果导出:

def on_export_clicked(self):
    if not self.sorted_records:
        print("[ERROR] 没有分拣记录,无法导出!")
        self.append_log("[ERROR] 没有分拣记录,无法导出!")
        return

    for rec in self.sorted_records:
        if "录音/录音" in rec[5]:
            rec[5] = rec[5].replace("录音/录音", "录音")
        if "录音\\录音" in rec[5]:
            rec[5] = rec[5].replace("录音\\录音", "录音")

    if not hasattr(self, 'output_base') or not self.output_base:
        self.append_log("[ERROR] 未找到输出目录,请先执行一键分拣操作!")
        return

    try:
        export.export_txt_and_copy(self.sorted_records, self.output_base, self.audio_folder)
        print("[INFO] 导出操作完成!")
        self.append_log("[INFO] 导出操作完成!")
        self.show_export_success_message()
    except Exception as e:
        print(f"[ERROR] 导出过程中出错: {e}")
        self.append_log(f"[ERROR] 导出过程中出错: {e}")

 

该函数确保整理后的音频文件被准确导出,同时生成一个包含音频路径的文本文件,方便律师后续查找与管理。

4. 多线程处理,确保界面流畅

在处理大量音频文件时,传统的单线程方式会导致界面卡顿或无响应。为了避免这种情况,我们使用了QThread来将音频归集的处理工作放到后台执行,从而保证界面的流畅性。

class MyWindow(QMainWindow, Ui_MainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)

        self.sorting_thread = None
        self.sorting_worker = None

    def on_deal_clicked(self):
        self.sorting_thread = QThread()
        self.sorting_worker = SortingWorker(
            excel_data=self.excel_df,
            audio_folder=self.audio_folder,
            output_base=self.output_base,
            org_code=self.jgdm_lineEdit.text().strip(),
            ent_name=self.qyjj_lineEdit.text().strip()
        )
        self.sorting_worker.moveToThread(self.sorting_thread)
        self.sorting_thread.started.connect(self.sorting_worker.run)
        self.sorting_worker.finished.connect(self.on_sorting_finished)
        self.sorting_worker.error.connect(self.on_sorting_error)
        self.sorting_worker.log_signal.connect(self.append_log)
        self.sorting_worker.progress_signal.connect(self.update_progress)
        self.sorting_thread.start()

在用户点击“开始处理”按钮时,程序会创建一个新的QThread线程并启动SortingWorker,后台进行音频文件的归集处理。在处理过程中,主线程仍然保持响应,用户可以查看进度条并实时获得操作日志。

结语

本项目展示了如何利用PyQt6多线程技术为律师事务所提供一个高效、自动化的音频证据整理工具。通过简单的图形化界面,用户无需复杂的操作就能完成音频文件的整理、归档和导出工作,大大提高了工作效率,减少了人工干预和错误。

未来,我们计划进一步优化工具,加入更多智能化功能,例如自动分析音频内容、支持更多格式的文件等,帮助律所应对更复杂的音频文件管理任务。

相关文章:

律所录音证据归集工具:基于PyQt6与多线程的自动化音频管理解决方案

在律所日常工作中,音频证据的整理与归集是一个高频且复杂的任务。面对大量的案件录音文件,如何实现快速且准确的分类与存档,成为了律所提高效率、降低出错率的关键。本文将通过技术角度解析一款名为律所录音证据归集工具的项目,详…...

【含开题报告+文档+PPT+源码】基于SpringBoot+Vue旅游管理网站

开题报告 本论文探讨了一款采用现代Web开发技术构建的台州市旅游综合信息与服务平台的设计与实现。该系统基于SpringBoot框架,以其轻量级、快速开发和强大的企业级应用支持能力为核心后端技术支撑,结合Vue.js前端框架及ElementUI组件库,为用…...

unity碰撞的监测和监听

1.创建一个地面 2.去资源商店下载一个火焰素材 3.把procedural fire导入到自己的项目包管理器中 4.给magic fire 0 挂在碰撞组件Rigidbody , Sphere Collider 5.创建脚本test 并挂在magic fire 0 脚本代码 using System.Collections; using System.Collections.Generic; usi…...

DeepSeek-R1 32B Windows+docker本地部署

最近国产大模型DeepSeek兴起,本地部署了一套deepseek同时集成Open WebUI界面,给大家出一期教程。 软件:Ollama、docker、Open WebUI 一、用Ollama下载模型 首先我们需要安装Ollama,它可以在本地运行和管理大模型。 到Ollama官网 https://ol…...

C++11新特性之unique_ptr智能指针

本节继续介绍智能指针,不了解的读者可以先阅读——C11新特性之shared_ptr智能指针-CSDN博客 1.介绍 unique_ptr是C11标准提供的另一种智能指针。与shared_ptr不同的是,unique_ptr指针指向的堆内存无法同其他unique_ptr共享,也就是每一片堆内…...

Vue与Konva:解锁Canvas绘图的无限可能

前言 在现代Web开发中,动态、交互式的图形界面已成为提升用户体验的关键要素。Vue.js,作为一款轻量级且高效的前端框架,凭借其响应式数据绑定和组件化开发模式,赢得了众多开发者的青睐。而当Vue.js邂逅Konva.js,两者结…...

python绘图之柱状堆积图的绘制

本节来学习用python来绘制柱状堆积图. 使用的库为matplotlib.pyplot,numpy 代码如下 # 导入必要的库 import matplotlib.pyplot as plt # 用于绘图 import numpy as np # 用于数值计算# 模拟一些数据 x [数值{}.format(i) for i in range(10)] # 创建一个包含10个元素的列…...

剪辑学习整理

文章目录 1. 剪辑介绍 1. 剪辑介绍 剪辑可以干什么?剪辑分为哪些种类? https://www.bilibili.com/video/BV15r421p7aF/?spm_id_from333.337.search-card.all.click&vd_source5534adbd427e3b01c725714cd93961af 学完剪辑之后如何找工作or兼职&#…...

DeepSeek从入门到精通:全面掌握AI大模型的核心能力

文章目录 一、DeepSeek是什么?性能对齐OpenAI-o1正式版 二、Deepseek可以做什么?能力图谱文本生成自然语言理解与分析编程与代码相关常规绘图 三、如何使用DeepSeek?四、DeepSeek从入门到精通推理模型推理大模型非推理大模型 快思慢想&#x…...

AI大模型训练实战:分布式与微调指南

AI大模型训练实战:分布式与微调指南 适用人群:有一定深度学习基础,正在或即将参与大模型(如 GPT、DeepSeek 等)训练与部署的工程师、研究者;想要理解分布式策略与微调方法的读者。 一、大模型为何需要分布式与微调? 随着 GPT、DeepSeek 等大模型参数规模攀升至数十亿甚…...

整合 Redis 分布式锁:从数据结构到缓存问题解决方案

引言 在现代分布式系统中,Redis 作为高性能的键值存储系统,广泛应用于缓存、消息队列、实时计数器等多种场景。然而,在高并发和分布式环境下,如何有效地管理和控制资源访问成为一个关键问题。Redis 分布式锁正是为了解决这一问题…...

并查集题目

并查集题目 聚合一块(蓝桥)合根植物(蓝桥)等式方程的可满足性省份数量 并查集(Union-Find)算法是一个专门针对「动态连通性」的算法。双方向的连通。 模板: class UF {// 连通分量个数private …...

日志2025.2.9

日志2025.2.9 1.增加了敌人挥砍类型 2.增加了敌人的死亡状态 在敌人身上添加Ragdoll,死后激活布偶模式 public class EnemyRagdoll : MonoBehaviour { private Rigidbody[] rigidbodies; private Collider[] colliders; private void Awake() { rigidbodi…...

支持多种网络数据库格式的自动化转换工具——VisualXML

一、VisualXML软件介绍 对于DBC、ARXML……文件的编辑、修改等繁琐操作,WINDHILL风丘科技开发的总线设计工具——VisualXML,可轻松解决这一问题,提升工作效率。 VisualXML是一个强大且基于Excel表格生成多种网络数据库文件的转换工具&#…...

Java并发编程笔记

Java并发基础知识补全 启动 启动线程的方式只有: 1、X extends Thread;,然后X.start 2、X implements Runnable;然后交给Thread运行 线程的状态 Java中线程的状态分为6种: 1. 初始(NEW):新创建了一个线程对象&…...

大语言模型实践——基于现有API的二次开发

基于现有的API平台做一些实用的AI小应用。 API服务商:阿里云百炼 云服务器:阿里云(2核2GB) 部署框架:gradio 调用框架:openai 语言:Python (注:若搭建网站或API接口…...

获取程序运行目录 (jar运行目录)

FileSystems.getDefault().getPath("").toAbsolutePath().toString() 和 Path.get(MyClass.class.getProtectionDomain().getCodeSource().getLocation().toURI()).getParent() 这两个代码片段在Java中用于获取不同的路径,尤其在打包为JAR文件运行时会有显…...

Elasticsearch:如何使用 Elastic 检测恶意浏览器扩展

作者:来着 Elastic Aaron Jewitt 当你的 CISO 询问你的任何工作站上是否安装过特定的浏览器扩展时,你多快能得到正确答案?恶意浏览器扩展是一个重大威胁,许多组织无法管理或检测。这篇博文探讨了 Elastic Infosec 团队如何使用 os…...

Oracle CDB自动处理表空间不足脚本

之前我曾经发过一个自动处理表空间的脚本,可以通过定时任务自动处理表空间不足的问题;但是之前那个脚本没有涵盖CDB模式下的PDB,这里将脚本做了一下更新,可以处理CDB模式下多PDB的表空间问题。 传统模式的脚本请参考这个链接 Or…...

java-list深入理解(流程图)

List源码学习: 此篇文章使用流程图和源码方式,理解List的源码,方便记忆 核心逻辑流程图: #mermaid-svg-BBrPrDuqUdLMtHvj {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-BBrPrDuqUdLMtHvj .error-icon{fill:#…...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序

一、开发准备 ​​环境搭建​​&#xff1a; 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 ​​项目创建​​&#xff1a; File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...

什么是EULA和DPA

文章目录 EULA&#xff08;End User License Agreement&#xff09;DPA&#xff08;Data Protection Agreement&#xff09;一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA&#xff08;End User License Agreement&#xff09; 定义&#xff1a; EULA即…...

使用 SymPy 进行向量和矩阵的高级操作

在科学计算和工程领域&#xff0c;向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能&#xff0c;能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作&#xff0c;并通过具体…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录&#xff0c;不允许匿名访问&#xff0c;kefu只能访问/data/kefu目录&#xff0c;不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

【分享】推荐一些办公小工具

1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由&#xff1a;大部分的转换软件需要收费&#xff0c;要么功能不齐全&#xff0c;而开会员又用不了几次浪费钱&#xff0c;借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...

C++.OpenGL (20/64)混合(Blending)

混合(Blending) 透明效果核心原理 #mermaid-svg-SWG0UzVfJms7Sm3e {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-SWG0UzVfJms7Sm3e .error-icon{fill:#552222;}#mermaid-svg-SWG0UzVfJms7Sm3e .error-text{fill…...

R 语言科研绘图第 55 期 --- 网络图-聚类

在发表科研论文的过程中&#xff0c;科研绘图是必不可少的&#xff0c;一张好看的图形会是文章很大的加分项。 为了便于使用&#xff0c;本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中&#xff0c;获取方式&#xff1a; R 语言科研绘图模板 --- sciRplothttps://mp.…...

PostgreSQL——环境搭建

一、Linux # 安装 PostgreSQL 15 仓库 sudo dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-$(rpm -E %{rhel})-x86_64/pgdg-redhat-repo-latest.noarch.rpm# 安装之前先确认是否已经存在PostgreSQL rpm -qa | grep postgres# 如果存在&#xff0…...

为什么要创建 Vue 实例

核心原因:Vue 需要一个「控制中心」来驱动整个应用 你可以把 Vue 实例想象成你应用的**「大脑」或「引擎」。它负责协调模板、数据、逻辑和行为,将它们变成一个活的、可交互的应用**。没有这个实例,你的代码只是一堆静态的 HTML、JavaScript 变量和函数,无法「活」起来。 …...