繁体   English   中英

尝试读取DBM文件

[英]Trying to read DBM file

我有一个精简的实时Linux盒,可以与某些硬件接口。

配置文件是* .dbm文件,我无法访问它们。 它们似乎是某种键值数据库,但是我尝试过的每个库都空了。

我曾经尝试过Perl,Python和Ruby的DBM读取库,但运气不佳。 这些文件的任何指导都很好,我之前从未见过。

当我将一个文件删除时,会发生这种情况。

 DBMFILE  Aug 31 2004,�
,jy                    �
�~���"��+�K&��gB��7JJ�
                                         ,��GLOBA.PB_COMBI�SMSI���
JG]
,��BUS_DP
PC  �
            '

xLokalT
          J��
                ,��SL_DP
                             PC!�
                                    ��
#,��PLC_PARAMJPf,��PROJEKT�PROFIBUS new network1.00022.02.2012J,��KBL_HEADER:�JJp,��KBLJ��,��ALI-SETUPB ����
������������������JJ,,��OBJ-DEFJJ��,��ALI_CLIENTTJJ�
,��ALI_SERVERJ      J\r�����2,  ��      ST_OV_00Boolean0Integer8    0Integer16
0Integer32
            0Unsigned8
0Unsigned32Floating-Point0igned16
Octet String Jo� ,��DESCRIPT �ABB OyABB Drives RPBA-01ABBSlave1***reserved***�
                                                                                      �
                                                                                      %  

因此,为了展示我已经尝试过的内容,并且只提出了空对象(没有键值)*编辑

perl-

#!/usr/bin/perl -w                                                                                                                                                                                                                             

use strict;

use DB_File;
use GDBM_File;

my ($filename, %hash, $flags, $mode, $DB_HASH) = @ARGV;

tie %hash,  'DB_File', [$filename, $flags, $mode, $DB_HASH]
  or die "Cannot open $filename: $!\n";

while ( my($key, $value) = each %hash ) {
   print "$key = $value\n";
}

 # these unties happen automatically at program exit                                                                                                                                                                                            
untie %hash;

什么都不返回

python-

db = dbm.open('file', 'c')

红宝石-

db = DBM.open('file', 666, DBM::CREATRW)

这些中的每一个都返回空了。 我假设他们使用相同的低级库。 DBM文件的一些历史记录/上下文可能很棒,因为似乎存在一些不同的版本。

**编辑

正在运行的文件返回

$ file abb12mb_uncontrolledsynch_ppo2_1slave.dbm 
abb12mb_uncontrolledsynch_ppo2_1slave.dbm: data

和运行字符串输出

$ strings abb12mb_uncontrolledsynch_ppo2_1slave.dbm 
DBMFILE  
Aug 31 2004
GLOBAL
PB_COMBI
SMSI
BUS_DP
Lokal
SL_DP
PLC_PARAM
PROJEKT
PROFIBUS new network
1 .000
22.02.2012
KBL_HEADER
ALI-SETUP
OBJ-DEF
ALI_CLIENT
ALI_SERVER
ST_OV_0
Boolean
Integer8
Integer16
Integer32
Unsigned8
Unsigned16
Unsigned32
Floating-Point
Octet String
DESCRIPT
ABB Oy
ABB Drives RPBA-01
ABBSlave1
***reserved***

为了使我的评论清楚,您应该尝试使用DB_File的默认选项,例如

use strict;
use warnings;

use DB_File;

my ($filename) = @ARGV;

tie my %dbm, 'DB_File', $filename or die qq{Cannot open DBM file "$filename": $!};

print "$_\n" for keys %dbm;

Perl的dbmopen函数文档中

[此功能已被tie函数取代。]

您可能想要尝试tie其与DB_File tie

 use DB_File;
 tie %hash,  'DB_File', $filename, $flags, $mode, $DB_HASH;

然后,您的数据在%hash

也可能是有趣的运行file对文件,看看它究竟是什么。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM