安卓手机爱奇艺app中离线视频导出
xsobi 2024-12-04 16:33 23 浏览
安卓手机爱奇艺app中离线视频导出:
通常我在爱奇艺中发现好的视频,想保存下来,点击离线缓存,缓存好后,在手机上可以查看,但是使用手机连接电脑打开后,发现保存视频的文件夹是空的。
1) 在手机中爱奇艺文件夹下找到已离线缓存的视频,路径在Android\data\com.qiyi.video\files\app\download\video里面,在手机上可以查看到,但是电脑上不行。
2) 在手机上对vide文件夹进行压缩,变成压缩包,还放在download下面,在从电脑上查看,发现download下多了个vide.zip的压缩包,把这个压缩包拷到电脑上,解压缩,就得到我们要的视频啦。
3) 拷到电脑上以后查看一下,发现vide文件夹下是一个个的文件夹,每个文件夹对应你下载的一个视频,让我们打开看一下吧。什么 ?没有发现我们熟悉的文件,不要着急,仔细找找,那个.qsv文件就是我们要找的视频文件。
4) 但是视频的名字为啥不对呢,因为爱奇艺在qiyicfg里放了这个视频的名字和信息。仔细看图中subTitle对应的那行就是视频的名字了。采用万国码进行编码的,有兴趣的朋友可以自己查找万国码码表自行翻译。
5) 那没兴趣的朋友,又想知道视频的名字咋办呢,下面是我自己写的一段Matlab的小程序,在Matlab里运行一下,就可以自己得出名字了,使用时记得把LinStr的值修改为你自己视频中的subTitle关键字后面对应的万国码。
LinStr='\u300A\u4E09\u4EE4\u4E94\u7533\u300B';
SubTit=strrep(LinStr,'subTitle=','');
HalSubTitLen=length(SubTit);
j=0;
DlsLen=1
DlcPath{DlsLen,3}='';
SubTitHex=[];
while(j<HalSubTitLen-1)
j=j+1;
if strcmp(SubTit(j:j+1),'\u')
SubTitHex=[strcat(SubTit(j+2),SubTit(j+3));strcat(SubTit(j+4),SubTit(j+5))];
SubTitDec=hex2dec(SubTitHex);
TemNam=native2unicode(uint8(SubTitDec'),'UTF-16BE');%解析后的工况名字
j=j+5;
if j>HalSubTitLen
DlcPath{DlsLen,3}=strcat(DlcPath{DlsLen,3},SubTit(j-5:HalSubTitLen));
break;
end
else
TemNam=SubTit(j);
end
DlcPath{DlsLen,3}=strcat(DlcPath{DlsLen,3},{TemNam});%第二个参数用胞元是为了合并空格时起作用
end
if j==HalSubTitLen-1
DlcPath{DlsLen,3}=char(strcat(DlcPath{DlsLen,3},SubTit(HalSubTitLen)));
end
DlcPath{DlsLen,3}
6) 要是很多个文件呢,总不能让我一个个的复制粘贴吧。下面我们编写一个自动的转换工具。使用时记得修改相应的路径啊,比如我把拷贝的video文件夹放在了E:\aiqiyi下面,PrjPath就设置为E:\aiqiyi,RunNam设置为video,NewRunNam是新命名后的视频存放的路径,可以不改名。运行这段程序后,你E:\aiqiyi\video下的所有文件夹下的视频会自动拷贝到E:\aiqiyi\newvideo下,并且名字已经变成你熟悉的名字了。
把PrjPath设置成你电脑上的video文件夹
%FindQiYiqsv用于查找qsv文件,并拷贝到newvideo文件夹下
clc;clear;
PrjPath='E:\aiqiyi';
RunNam='video';
NewRunNam='newvideo';
NewPrjPath=strcat(PrjPath,'\',NewRunNam);
mkdir(NewPrjPath);
Path=strcat(PrjPath,'\',RunNam);
ListName{1,1}=Path;
first=1;%ListName的当前元素下标
rear=1;%ListName的最后一个元素下标
DlcPath={};%各工况路径及名称
DlsLen=0;%工况个数
disp('开始搜索...');
while(1)
disp(char(strcat('正在搜索第',num2str(first),'个文件夹,名为"',Path,'"')));
SubPath=dir(Path);
Len=length(SubPath)-2;
for i=1:Len
if ~SubPath(i+2,1).isdir%判断是否为文件夹
PjNamPos=findstr(SubPath(i+2,1).name,'.qsv');%*.$TE文件中记录了工况是否正确仿真完
if PjNamPos
DlsLen=DlsLen+1;
DlcPath{DlsLen,1}=Path;%DlcPath中记录各小工况的路径
DlcPath{DlsLen,2}=SubPath(i+2,1).name(1:PjNamPos-1);%工况名字
%文件名字解析
fid=fopen(strcat(DlcPath{DlsLen,1},'\',DlcPath{DlsLen,2},'.qiyicfg'),'r');
while ~feof(fid)
LinStr=fgetl(fid);
if findstr(LinStr,'subTitle=')
break;
end
end
fclose(fid);
SubTit=strrep(LinStr,'subTitle=','');
HalSubTitLen=length(SubTit);
j=0;
DlcPath{DlsLen,3}='';
SubTitHex=[];
while(j<HalSubTitLen-1)
j=j+1;
if strcmp(SubTit(j:j+1),'\u')
SubTitHex=[strcat(SubTit(j+2),SubTit(j+3));strcat(SubTit(j+4),SubTit(j+5))];
SubTitDec=hex2dec(SubTitHex);
TemNam=native2unicode(uint8(SubTitDec'),'UTF-16BE');%解析后的工况名字
j=j+5;
if j>HalSubTitLen
DlcPath{DlsLen,3}=strcat(DlcPath{DlsLen,3},SubTit(j-5:HalSubTitLen));
break;
end
else
TemNam=SubTit(j);
end
DlcPath{DlsLen,3}=strcat(DlcPath{DlsLen,3},{TemNam});%第二个参数用胞元是为了合并原文件名中的空格
end
if j==HalSubTitLen-1
DlcPath{DlsLen,3}=strcat(DlcPath{DlsLen,3},SubTit(HalSubTitLen));
end
DlcPath{DlsLen,3}=char(DlcPath{DlsLen,3});
if(isempty(DlcPath{DlsLen,3}))
DlcPath{DlsLen,3}=DlcPath{DlsLen,2};
end
%去掉文件名中的非法字
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'\','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'/','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},':','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'*','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'?','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'"','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'<','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'>','');
DlcPath{DlsLen,3}=strrep(DlcPath{DlsLen,3},'|','');
%文件拷贝
if DlsLen<10
OrdStr=strcat('00_',num2str(DlsLen));
elseif DlsLen<100
OrdStr=strcat('0_',num2str(DlsLen));
else
OrdStr=strcat('_',num2str(DlsLen));
end
OrdStr='';
try
copyfile(strcat(DlcPath{DlsLen,1},'\',DlcPath{DlsLen,2},'.qsv'),strcat(NewPrjPath,'\',DlcPath{DlsLen,3},'.qsv'),'f');
catch
disp(DlcPath{DlsLen,1});
return;%直接结束程序,下面的不运行了;break是直接结束本循环
end
%pause(1);
end
else
rear=rear+1;
ListName{rear,1}=strcat(Path,'\',SubPath(i+2,1).name);
end
end
first=first+1;
if first>rear
break;
end
Path=ListName{first,1};
end
disp(strcat('搜索完毕,共搜索',num2str(first-1),'个文件夹,找到',num2str(DlsLen),'个文件.'));
% Unicode表
% label=[];
% for i=1:255
% for j=1:255
% label{i,j}=native2unicode(uint8([i-1;j-1]'),'UTF-16BE');
% end
% i
% j
% end
相关推荐
- 阮一峰高质量免费 TypeScript 教程,适合有 JS 基础的人系统学习 TS
-
好长时间没有分享前端教程了,就在前几天,阮老师发布了历经一年多时间编写的TS教程,第一时间去阅读学习了,也分享给大家。早在“那些免费的砖”这个网站的建站之初,我就向大家推荐了两个JavaScri...
- HTML序章(学习目的、对象、基本概念)——零基础自学网页制作
-
为什么学习网页制作?互联网时代的今天,各种各样的网页充斥着我们的生活。只要使用浏览器,打开的每一个页面都可以称之为网页。即使使用头条这样的APP,其内容布局、展示的方法也脱胎于网页页面设计的方法与原则...
- 网页内嵌PDF获取的办法(网页内嵌pdf如何下载源文件)
-
最近女王大人为了通过某认证考试,交了2000RMB,官方居然没有给线下教材资料,直接给的是在线教材,教材是PDF的但是是内嵌在网页内,可惜却没有给具体的PDF地址,无法下载,看到女王大人一点点的截图保...
- pdfkit | 利用python实现html文件转pdf
-
在用jupyternotebook写代码文档的时候,有时需要导出pdf版本,但jupyter会报错。我在想,除了网上的debug方法,还没有其他方案可以生成pdf。度娘搜了下,很多博客推荐Pytho...
- 在PDF中运行《毁灭战士》:突破文档边界的技术实验
-
DoomPDF是一个将经典射击游戏《毁灭战士》(Doom)嵌入PDF文件的开源项目。通过巧妙利用PDF格式的隐藏特性,这项实验成功打破了”PDF只能展示静态内容”的固有认知,让用户可以直接在浏览器中...
- 怎么转换PDF格式文件?这5款免费网站真的好用!
-
PDF文件是工作学习中的常客,在使用过程中,常常需要对PDF格式进行转换,包括但不限于PDF转Word、PDF转PPT、PDF转图片等等。不过WPS虽然应用广泛,但是里面关于PDF的转换工具必需要会员...
- 最值得使用的html格式生成PDF工具!
-
这些工具将任意数量的HTML文件准确的同时保留原来的布局不要求你做任何操作就可以完成。现在互联网用户,网站发布者和博客更新很快,通过内置的工具易于访问HTML内容的PDF文件。保持HTML文本或图像的...
- 有没有什么方法能将PDF转为HTML呢?PDF转HTML的最佳6个方法
-
HTML是什么?HTML是超文本标记语言(HyperTextMarkupLanguage),标准通用标记语言下的一个应用。HTML不是一种编程语言,而是一种标记语言(markuplangu...
- 如何实现将PDF和html相互转换(pdf做成html)
-
PDF是一种比较稳定的电子文档格式,而HTML则是一种通用的网页格式,如何才能实现这两种格式之间的互转呢?首先将网页转成PDF是相当来说比较简单的操作,而且只要我们对PDF格式比较熟悉,一定都知道PD...
- Mac系统中怎么将html网页转成PDF格式?
-
Mac系统中怎么将html网页转成PDF格式?mac系统中把网页格式的文件想转换成pdf格式的文件,方便打印,该怎么转换呢?下面我们就来看看详细的教程,需要的朋友可以参考下。用途:把网页html转成p...
- 浏览器中在线预览pdf文件,pdf.mjs插件实现web预览pdf
-
背景:本来只是淘宝上卖卖袜子,想着扩展一下业务,准备做同名“来家居”海外袜子馆外贸项目,碰到pdf在线预览的需求,就找了pdf.js插件进行实践后把此方法记录下来,可以通过多种方法来实现,每种方法都有...
- 前端利用Print.js打印base64 PDF(前端利用Print.js打印base64 pdf viewer)
-
关于Print.jsPrint.js库在https://printjs.crabbly.com/有说细的说明,总体来说其兼容还具有一定的局限性。Print.js项目中的使用我们的打印功能运行在Goog...
- ChromiumHtmlToPdf:Net跨平台轻松将HTML转换为PDF
-
什么是ChromiumHtmlToPdf?ChromiumHtmlToPdf是一个100%纯托管的C#.NETStandard2.0库和.NET8控制台应用程序,也适用于Li...
- PDF动画电子书如何制作?(如何制作pdf动图)
-
PDF无法制作成动画的,但是可以换个思路,把PDF转换为翻页电子书,即可支持动画。这里推荐一款上传PDF转换为翻页电子书的网站:FLBOOK,可以免费上传PDF,转换为可以具有真书翻页特效的电子书,并...
- HtmlToPDFCore:HTML 转换为 PDF 的利器,轻便,快捷,重量级
-
在日常开发中,我们常常需要将动态生成的HTML内容转换为PDF文件。无论是用于打印、存档还是分享,PDF格式都因其跨平台兼容性和稳定性而备受青睐。今天,我们就来介绍一个强大的工具——Htm...
- 一周热门
- 最近发表
- 标签列表
-
- grid 设置 (58)
- 移位运算 (48)
- not specified (45)
- 导航栏 (58)
- context xml (46)
- scroll (43)
- dedecms模版 (53)
- c 视频教程下载 (33)
- listview排序 (33)
- characterencodingfilter (33)
- getmonth (34)
- label换行 (33)
- android studio 3 0 (34)
- html转js (35)
- 索引的作用 (33)
- checkedlistbox (34)
- xmlhttp (35)
- mysql更改密码 (34)
- 权限777 (33)
- htmlposition (33)
- 学校网站模板 (34)
- textarea换行 (34)
- 轮播 (34)
- asp net三层架构 (38)
- bash (34)