我有一个文件,其中一些行包含一个编码为text ->二进制-> octets的数字,我需要对其进行解码才能得到数字。该编码字符串所在的所有行都以STRVID开头:
例如,我有一句台词:
STRVID: SarI3gXp如果我做这个回波"SarI3gXp“\ perl -lpe‘$_=unpack”B*“,我会得到二进制数
0101001101100001011100100100100100110011011001110101100001110000现在,为了从二进制解码为octets,我这样做(将前面的命令分配给变量,然后将二进制转换为octets )。
variable=$(echo "SarI3gXp" | perl -lpe '$_=unpack"B*"') ; printf '%x\n' "$((2#$variable))"结果是数字,而不是正确的顺序。
5361724933675870要得到前一个数字的正确顺序,我必须得到每一对数字,首先,第二个数字,然后第一个数字,最后得到我想要的数字。就像这样:
variable=$(echo "SarI3gXp" | perl -lpe '$_=unpack"B*"') ; printf '%x\n' "$((2#$variable))" | gawk 'BEGIN {FS = ""} {print $2 $1 $4 $3 $6 $5 $8 $7 $10 $9 $12 $11 $14 $13 $16 $15}'最后,我找到了我要找的号码:
3516279433768507对于我的文件中以STRVID:开头的每一行,我都不知道如何自动做到这一点。最后,我需要的是整个文件,但是当一行以STRVID开头时:则需要解码的值。
当我发现这个:
STRVID: SarI3gXp我会在我的档案里
STRVID: 3516279433768507有人能帮忙吗?
发布于 2022-07-14 14:06:08
首先,转换所需的全部条件是
unpack "h*", "SarI3gXp"使用-p的perl一行程序将为每一行执行所提供的程序,而s///e允许我们修改以代码作为替换表达式的字符串。
perl -pe's/^STRVID:\s*\K\S+/ unpack "h*", $& /e'发布于 2022-07-14 09:39:47
请查看以下示例演示代码片段,以了解是否符合您的问题。
当可以一次完成时,不需要双重转换。
use strict;
use warnings;
use feature 'say';
while( <DATA> ) {
chomp;
/^STRVID: (.+)/
? say 'STRVID: ' . unpack("h*",$1)
: say;
}
__DATA__
It would be nice if you provide proper input data sample
STRVID: SarI3gXp
Perhaps the result of this script complies with your requirements.
To work with real input data file replace
while( <DATA> ) {
with
while( <> ) {
and pass filename as an argument to the script.输出
It would be nice if you provide proper input data sample
STRVID: 3516279433768507
Perhaps the result of this script complies with your requirements.
To work with real input data file replace
while( <DATA> ) {
with
while( <> ) {
and pass filename as an argument to the script../script.pl input_file.dat
发布于 2022-07-14 09:17:22
您可以完全通过regex (也不需要反向引用)交叉翻转数字:
Variable=$(回声"SarI3gXp“\ perl -lpe‘$_=unpack’B*‘);printf '%x\n’”$(2#$variable))“{{e76f} mawk -F'^$‘’gsub(”.“,"_&=&_") + gsub(\”(^x 0-9_)(_0-9 x$)“,_)+gsub("=",_)^_‘’
1 3516279433768507这样做的目的是在另一边复制一个副本,如下所示:
_53=53__61=61__72=72__49=49__33=33__67=67__58=58__70=70_
然后擦掉剩菜,因为你现在想要的数字是锚定每个等号的两边("=")。
https://stackoverflow.com/questions/72976624
复制相似问题