试图读取DBM文件

时间:2015-01-15 15:09:37

标签: python c linux perl dbm

我有一个剥离的实时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***

2 个答案:

答案 0 :(得分:1)

为了明确我的评论,您应该尝试使用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;

答案 1 :(得分:0)

来自documentation for Perl's dbmopen function

  

[这个功能在很大程度上被领带功能所取代。]

您可能希望tie尝试 use DB_File; tie %hash, 'DB_File', $filename, $flags, $mode, $DB_HASH;

%hash

然后您的数据位于file

对文件运行{{1}}可能也很有趣,看看它到底是什么。