python - 尝试读取 DBM 文件

标签 python c linux perl dbm

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

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

我尝试了 Perl、Python 和 Ruby 的 DBM 读取库,但没有成功。任何关于这些文件的指导都会很棒,我以前从未见过它们。

这是我 cat 一个文件时发生的情况。

 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')

ruby -

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;

关于python - 尝试读取 DBM 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27966496/

相关文章:

python - 使用 Tensorflow 2.1 加载自定义模型

python - 从 Python 3.5 编译 Oracle 包时,不会填充 Oracle 12c DBA_IDENTIFIERS

python - 在 python 中解压嵌套的 zip 文件

c - 在 Windows 上用 C 搜索文件

linux - 如何使用 linux 命令从纯文本文件中删除重复的单词

python - django.db.utils.OperationalError : 1005, 'Can' t创建表 `xyz` .`#sql-600_237`(错误号:150 "Foreign key constraint is incorrectly formed")

c - 相同枚举类型的不同大小

c - Glibc 和 uClibc 并排在一个系统上

python - 从 Anaconda 运行 Python 时出现 ImportError : No module named sysconfig,

python - 按第 1 列和标题行重新排列外部参照/csv