免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 47153 | 回复: 33

[文本处理] linux下sed,或perl 怎么以16进制操作文件? [复制链接]

论坛徽章:
0
发表于 2016-08-13 23:30 |显示全部楼层
本帖最后由 sofs 于 2016-08-14 08:49 编辑

1.png

左边是原文件,右边是我替换了内容后的文件。

我用的命令是 perl -p -i -e 's/\x48\x5c\x00\x00\x00\x00\x00\x00\x03\x80.*//g' ./file.gz

需求是要将左边 1 红框后面的内容全部删除掉。用了上面那个perl替换命令后,只是删除掉了一部分内容(右边空白处就是被删除的),而后面还有一大段内容没被删除(2)。

研究了很久,sed,tr这些都试了,没找到方法,求大神指点。

下面是原附件。

file.gz (2.31 KB, 下载次数: 17)

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
发表于 2016-08-14 00:23 |显示全部楼层
我下载下来不能解压缩, 总是提示 not in zip format.

论坛徽章:
0
发表于 2016-08-14 08:38 |显示全部楼层
回复 2# sunzhiguolu


    不是要解压,而是要直接以16进制操作这个file.gz文件。

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
发表于 2016-08-14 11:05 |显示全部楼层
谢谢提醒, 才发现是个二进制文件.

论坛徽章:
0
发表于 2016-08-14 16:57 |显示全部楼层
回复 4# sunzhiguolu


  大神,  有办法搞定吗?

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
发表于 2016-08-15 13:45 |显示全部楼层
是要删除从第一次出现\x48\x5c\x00\x00\x00\x00\x00\x00\x03\x80到文件末尾的内容吗?

论坛徽章:
0
发表于 2016-08-16 12:58 |显示全部楼层
回复 6# moperyblue


  是要删除  \x48\x5c\x00\x00\x00\x00\x00\x00\x03\x80 后面的所有内容,\x48\x5c\x00\x00\x00\x00\x00\x00\x03\x80 需要保留。

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
发表于 2016-08-16 14:01 |显示全部楼层
回复 7# sofs


    后面的所有内容 指到文件末尾是吧 还是仅到行末?

论坛徽章:
0
发表于 2016-08-16 14:28 |显示全部楼层
本帖最后由 sofs 于 2016-08-16 14:29 编辑

回复 8# moperyblue


    刚刚我说错了。

放到实际情况中,(而不仅仅是处理这个一个文件),我图片里面标示1的地方 才是特征码。也就是 7D 81 AO 3E C1 A7

需求是将7D 81 AO 3E C1 A7后面的所有内容全部删除,直到文件的最后一个字节都要删除,也就是你说的文件尾端,但是7D 81 AO 3E C1 A7要保留下来。

论坛徽章:
0
发表于 2016-08-16 14:31 |显示全部楼层
在perl 的板块,有个大神用perl 方法解决了这个问题。你可以去看看。

有兴趣的话可以研究研究其他实现方法
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP