能够将 mkv 文件转储为某些文本(例如在 mkvinfo -v 中)、编辑它并重建回来,例如将二进制数据保留为十六进制转储,这将很有用。
类似于:
$ mkv2xml < test.mkv > test.xml
$ head test.xml
<EBML>
<EBMLVersion>1</EBMLVersion>
<MaxIdLen>4</<MaxIdLen>
<MaxSizeLen>8</MaxSizeLen>
<DocType>matroska</DocType>
<DocTypeVersion>2</DocTypeVersion>
<DocTypeReadVersion>2</DocTypeReadVersion>
<Segment>
<Tracks>
<Track>
<TrackNumber>1</TrackNumber>
<CodecID>V_MJPEG</CodecID>
<Video><PixelWidth>320</PixelWidth><PixelHeight>240</PixelHeight></Video>
</Track>
</Tracks>
<Cluster>
<Timecode>5.023</TimeCode>
<SimpleBlock track="1" time="5.045">
ffd8fffe001a80......
$ xml2mkv < test.xml | mplayer -cache 100 -
这对于简化编写处理视频的 [调试] 工具很有用,而不会真正弄乱复用/解复用细节,只需查看输出即可。
最佳答案
我自己用 Python 实现:https://github.com/vi/mkvparse
可以转换为 xml,更改某些内容(例如使用 xml2/2xml ),转换回来并在一个管道中播放。
示例 XML 文件:http://vi-server.org/pub/xml2mkv_test.xml
此处修剪(甚至更多)片段:
<mkv2xml>
<EBML>
<EBMLVersion>1</EBMLVersion>
<DocType>matroska</DocType>
</EBML>
<Segment>
<Info>
<TimecodeScale>1000000</TimecodeScale>
<MuxingApp>libebml v1.0.0 + libmatroska v1.0.0</MuxingApp>
<Duration>46665.0</Duration>
<DateUTC>1282406803.0</DateUTC>
<SegmentUID>9d516a0f927a12d286e1502d23d0fdb0</SegmentUID>
</Info>
<Tracks>
<TrackEntry>
<TrackNumber>1</TrackNumber>
<TrackType>1</TrackType>
<CodecID>V_MPEG4/ISO/AVC</CodecID>
<CodecPrivate>
014d401fffe10014274d401fa918080093600d418041adb0ad7bdf0101000428
ce09c8
</CodecPrivate>
<Video>
<PixelWidth>1024</PixelWidth>
<PixelHeight>576</PixelHeight>
</Video>
</TrackEntry>
<TrackEntry>
<TrackNumber>2</TrackNumber>
<TrackType>2</TrackType>
<CodecID>A_AAC</CodecID>
<Audio>
<SamplingFrequency>48000.0</SamplingFrequency>
<Channels>2</Channels>
</Audio>
</TrackEntry>
<TrackEntry>
<TrackNumber>3</TrackNumber>
<CodecID>S_TEXT/UTF8</CodecID>
</TrackEntry>
...
</Tracks>
<Cluster>
<Timecode>0</Timecode>
<SimpleBlock>
<track>1</track>
<timecode>0.0</timecode>
<keyframe/>
<data>
00004e1925b82001ebd34d359f84a010001019b0f94a107609ec4dc0b6341175
98899cbb3a0a9de562532111ed77f7876006014200856a5fc3c2ccdf6e10a385
...
</data>
</SimpleBlock>
<SimpleBlock>
<track>10</track>
<timecode>0.009</timecode>
<keyframe/>
<data>
01449ffe0b246a488f09c715768924b01aa2e9b2415aaa29e4696becea270d36
a0d565bd24d5e6f09f3d4e000a8f192aa6aaa071f2ba14bd2fa14d633ad665ee
72e92eadce23415fd6bb871941941b1bfd5b0e75ad6826755e61ef5483f93cd3
82d61c779fa74b4acd62572b399ac3d9039900e94a5c542e4110dd29b65e2000
220011a10c00000000b0a8540100880380
</data>
<data>
0144d7902c180b04c28161a8482a160a048aa1209848423208cdeed6de7c6b7a
.....
</data>
...
</SimpleBlock>
<BlockGroup>
<Block>
<track>4</track>
<timecode>0.042</timecode>
<duration>3.375</duration>
<data encoding="text"><![CDATA[A jobb oldaladon láthatod...
...tudod mit...]]></data>
</Block>
<BlockDuration>3375</BlockDuration>
</BlockGroup>
<BlockGroup>
<Block>
<track>5</track>
<timecode>0.042</timecode>
<duration>3.375</duration>
<data encoding="text"><![CDATA[Auf der rechten Seite sieht man...|...rate mal...]]></data>
</Block>
<BlockDuration>3375</BlockDuration>
</BlockGroup>
</Cluster>
</Segment>
</mkv2xml>
关于xml - 是否有任何工具可以将 matroska (mkv) 与文本文件相互转换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10453832/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
我试图在索引页中创建一个超链接,但它没有显示,也没有给出任何错误。这是我的index.html.erb代码。ListingarticlesTitleTextssss我检查了我的路线,我认为它们也没有问题。PrefixVerbURIPatternController#Actionwelcome_indexGET/welcome/index(.:format)welcome#indexarticlesGET/articles(.:format)articles#indexPOST/articles(.:format)articles#createnew_articleGET/article
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案