0

我正在尝试将一些形状文件导出到 MySQL 数据库。

我可以使用 PHP 读取 shp features dbf 文件,但我希望能够为我正在循环的每一行获取 WKT 空间数据。我曾想过在qgis中的shp文件字​​段中添加一个计算字段(geomToWKT),但不幸的是dbf文件中字符串字段属性的长度限制为254个字符。我怎样才能得到每一行对应的 wkt?

function process_dbf($dbf_path) {
  $db = dbase_open($dbf_path, 0);
  if($db) {
    $record_numbers = dbase_numrecords($db);
    for ($i = 1; $i <= $record_numbers; $i++) {
      $row = dbase_get_record_with_names($db, $i);

      $name= $row['name'];
      $name=$row['area'];
      $x=$row['x'];
      $y=$row['y'];
      $notes=$row['notes'];
      $owner=$row['owner'];
      $id=$row['ID'];
      $tel=$row['tel_'];
      $wkt=geomToWKT(geometry); //what I am trying to achieve in PHP
  }
  }
}}
4

2 回答 2

1

好的。终于设法让它工作了。

你将需要这个课程。此外,如果您使用的是 Windows,您将需要PHP 5.4 上的这个 dbase 扩展

include 'PHP5-Shape-File-Parser-master/shpParser.php';
function process_shp($shp_location,$dbf_location) {
$parser=new shpParser();
$parser->load($shp_location);
$db = dbase_open($dbf_location, 0);
$data=$parser->getShapeData();
$i=1;
foreach($data as $shprow) {
    $datarow=dbase_get_record_with_names($db, $i);
    $i++;
    //print_r($shprow); for shp geo spatial data (shp)
    //print_r($datarow); for shp feature data (dbf)
}
}
process_shp('Jerusalem/BeitHanina/entrances/New_Shapefile-new.shp';
'Jerusalem/BeitHanina/entrances/New_Shapefile-new.dbf'); //for example
于 2014-10-28T08:19:09.637 回答
1

我发布这个迟到的答案只是作为社区服务,因为这是在寻找“将 ESRI Shapefiles 转换为 WKT”时弹出的问题之一。

我的PHP Shapefile库可以读取和写入任何 ESRI Shapefile 并将其本地转换为WKTGeoJSON

它不需要任何第三方依赖,也不需要 dBase 扩展(在大多数现代 PHP 环境中不可用)并且它是积极维护的。

于 2019-08-30T15:40:34.227 回答