如何在二进制文件中搜索字符串并输出bash中字符串之前的字节数

问题描述

我不会拆分文件

#!/bin/bash
var=bytes

split -b $var filetocut

但是为了做到这一点,我需要知道要剪切多少字节

lookforstring --string="#!/usr/bin/env xdg-open" --file=filetocut

输出是 123

split -b 123 filetocut

bash 中是否有执行此操作的命令

解决方法

您可以将 grep--text--byte-offset--only-matching 选项一起使用:

lookforstring() (
    string="$1"
    filetocut="$2"
    grep --text --byte-offset --only-matching "$string" "$filetocut" | awk -F: '{print $1}'
)

(函数体是 POSIX-ly 的子shell,如果这些变量是在脚本的其他地方定义的,则防止覆盖 stringfiletocut。)

用法:

lookforstring '#!/usr/bin/env xdg-open' "$filetocut"

--text 选项告诉 grep 像处理文本一样处理二进制文件。默认情况下,grep 仅输出一条说明二进制文件匹配的单行消息,而 --text 选项阻止了这种默认设置。

--byte-offset--only-matching 结合使用时,将在找到匹配部分的文件中打印字节偏移量。

最后的awk部分是只提取偏移部分。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...