借助常见工具快捷实现录音文件的查找与导出[通俗易懂]

借助常见工具快捷实现录音文件的查找与导出

大家好,又见面了,我是全栈君。

近期blhy的客户提出这个需求,对方提供一批来电的流水号,让我们给出对应的录音文件。

传统的情况下,客户方一般须要的是某一段时间内的录音,因为系统中的录音文件的文件名称是依照年月日时分秒这个规则去命名的。所以这样的情况下用命令查找和打包都比較方便。而如今是对方给我们的仅仅是一段时间内的指定流水号。

讲到这里你可能有两种思路:(1)看看这些流水号大致落在哪个时段范围内的,把这段时间内的录音文件所有打包导出,然后再从当中摘取目的文件。(2)将流水号拷贝过来,挨个从系统中去查找和下载录音文件。

个人觉得这两种方法都有点问题,针对思路(1),假设总的录音文件少的话,还比較优点理,假设录音文件多的话。简直就是场灾难,首先你打包文件须要时间。另外你再从当中去找的话。无异于大海捞针。这里先假定录音文件名称和流水号在名称上有相应关系。针对思路(2),挨个查找比較靠谱,可是假设对方给出的列表比較长的话。这就是一项反复的工作,伤神费力,也是一场灾难。

通过观察发现。blhy提供的流水号是与录音文件名称没有直接的关系的,所以我的思路是:先试图通过流水号去找到录音文件名称中的局部或者所有(通过excel去匹配。主要是找到相应关系)。然后组装命令(editplus工具或者其它)。写成shell脚本。通过运行shell脚本去查找这些录音文件并打包压缩,最后通过winSCP工具导出到本地。

于是,依照这个思路,分以下几步走:

 

1、在数据库的call_pickup_specimen_info表中。存储的有流水号与录音文件名称局部的相应关系,流水号是specimen_code这个字段,局部的录音文件名称是userfield_id这个字段。于是通过在数据库中运行查找这两列的sql语句(比如SELECT specimen_code,userfield_id FROM `call_pickup_specimen_info` where specimen_code BETWEEN ‘2014090100110054’ and ‘2014090623595954’)。将这两列的数据查询出来。全选,拷贝到excel中;

2、将查找的流水号数据拷贝到excel的sheet2中。使用excel的VLOOKUP函数,将sheet2中的流水号相应的录音文件名称局部的userfield_id信息匹配出来。

3、通过匹配得到userfield_id信息后,要考虑拼接linux命令了,完整的linux命令类似“find /var/spool/asterisk/monitor/1 -name ‘*20140825*’ | xargs zip “/opt/blhytest.zip”。能够非常明显的看出,我们须要在刚刚匹配出来的userfield_id信息的前后分别加上一段固定的内容。来拼接成我们所须要的linux命令。不喜欢黄师傅用的Notepad++。一直喜欢使用editplus这个文本编辑工具,推荐。将userfield_id拷贝到editplus之后,通过全选文本内容–右键“格式”–行凝视–输入凝视符,这里我写的是“find /var/spool/asterisk/monitor/1 -name ‘*”。也即命令的前半部分;通过“搜索”–“替换”菜单。将“\n”替换为“*’ | xargs zip “/opt/blhytest.zip” \n”,注意勾选以下的“使用正則表達式”,就可以在每行的末尾增加固定的内容,至此我们的命令已经拼接完毕了,非常快,至少比excel要快。

4、将该文件保存为.sh格式的文件,比如我写的是blhyexport.sh,通过winSCP工具上传到server上随意文件夹下。自己记得这个路径即可;

5、使用 “chmod 777 blhyexport.sh”。为该文件授权;

6、通过”./blhyexport.sh”就能够运行该脚本打包录音文件了,屏幕闪现的是一行行的运行过程,整个打包的过程非常快;

7、打包完成。通过winSCP工具。分分钟就能够将打包的录音文件下载到本地了,这个压缩包里面的录音文件正是你想要的。

 

传统的依次复制流水号去查询并下载,须要浪费两三个小时甚至是一下午时间(视任务量多少而定),而使用上述方法,不论任务量有多少,不超过10分钟就能够搞定了。

借助于我们熟悉的excel、editplus、linux命令,能够帮助我们快捷高效地完毕任务。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/116644.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • java将Word转换成PDF

    java将Word转换成PDF网上有很多将Word转换成PDF的方式,这里找了两种比较简单的工具:jacob和aspose。1.jacob使用Jacob需要一些环境的准备,首先需要Jacob的jar包:然后还需要将jacob版本对应的ddl文件放到jdk或jre的bin目录里:下面只需要使用写好的工具类就可以了:publicclassWord2PdfJacobUtil{ /*转PDF格…

  • STL库 总览_stl库函数

    STL库 总览_stl库函数  STL库1泛型程序设计2STL标准模板库2.1STL库的基本组件2.1.1STL基本组件—-容器2.1.2STL基本组件—-迭代器2.1.3STL基本组件—-函数对象2.1.4STL基本组件—-算法3迭代器4容器的基本功能与分类4.1顺序容器  1泛型程序设计  泛型程序设计就是时候,将程序设计的尽量的通用。STL标准库就是泛型程序设计的一个很好的范例。  ◇编写不依赖具体数据类型的程序;  ◇将算法从特定的数据结构中抽象出来,成为通用的;  ◇

    2022年10月10日
  • linux接收snmptrap_icmp报文封装在ip包的数据部分

    linux接收snmptrap_icmp报文封装在ip包的数据部分 转:http://blog.chinaunix.net/uid-20644632-id-4115863.html使用snmptrap发送SNMPtrap2014-02-2113:55:33分类:LINUX 使用snmptrap发送SNMPtrap冷胜魁(Seaquester)lengshengkui@gmail.com2014-01-15…

  • SQL XQuery COUNT函数

    SQL XQuery COUNT函数

  • 四、网页信息存储和 BeautifulSoup之find用法

    四、网页信息存储和 BeautifulSoup之find用法网页信息存储和BeautifulSoup之find用法前言一、BeautifulSoup之find用法findfind_all具体使用示例二、网页信息存储1.基础知识2.写入数据总结前言上一章更新时时间太过匆忙,在这一章会解决上一章结尾问题BeautifulSoup之find用法,并进入爬虫的第三个流程,信息存储。一、BeautifulSoup之find用法BeautifulSoup有find和find_all的方法。但在使用之前一定要先建立一个beautifulsoup对象。find只

  • 手机号验证最新正则表达式「建议收藏」

    一般表单页面都需要填写手机号,校验用户输入的手机号码是否正确,就要用到正则表达式,用正则表达式来匹配手机号段,如在运营商号段内,则号码正确。因此,需要知道运营商最新的号段,如下所示:各大运营商手机号码段(新)中国电信号段133、153、173、177、180、181、189、190、191、193、199中国联通号段130、131、132、145、155、156、166、167、171、175、176、185、186、196中国移动号段134(0-8)、135、136、137、138

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号