不幸的是,dbase 函数没有编译到我的商业服务器的 php 中,我需要读取 shape 文件中的一些地理数据,其中包含 dbfs 中的数据。
所以这可能对其他人有所帮助
<?php
function echo_dbf($dbfname) {
$fdbf = fopen($dbfname,'r');
$fields = array();
$buf = fread($fdbf,32);
$header=unpack( "VRecordCount/vFirstRecord/vRecordLength", substr($buf,4,8));
echo 'Header: '.json_encode($header).'<br/>';
$goon = true;
$unpackString='';
while ($goon && !feof($fdbf)) { $buf = fread($fdbf,32);
if (substr($buf,0,1)==chr(13)) {$goon=false;} else {
$field=unpack( "a11fieldname/A1fieldtype/Voffset/Cfieldlen/Cfielddec", substr($buf,0,18));
echo 'Field: '.json_encode($field).'<br/>';
$unpackString.="A$field[fieldlen]$field[fieldname]/";
array_push($fields, $field);}}
fseek($fdbf, $header['FirstRecord']+1); for ($i=1; $i<=$header['RecordCount']; $i++) {
$buf = fread($fdbf,$header['RecordLength']);
$record=unpack($unpackString,$buf);
echo 'record: '.json_encode($record).'<br/>';
echo $i.$buf.'<br/>';} fclose($fdbf); }
?>
此函数仅使用 echo 和 json_encode 导出整个文件,因此您可以根据自己的需要进行调整……(例如,随机访问只需要更改 seek 为:fseek($fdbf, $header['FirstRecord']+1 +($header['RecordLength']* $desiredrecord0based); 删除 for 循环并返回 $record)
此函数不执行任何类型转换,但如果需要处理日期或整理数字等,它会提取类型。
快速且简陋,但可能对某些人有用,并说明了 unpack 的强大功能。
Erich