2

非常に長いmysqlラインストリングを配列に変換する最良の方法は(ポイントごとに)、爆発を使用するのが方法だと思いますが、文字列パラメーターを渡して爆発させる前に、少しテキスト操作が必要です。

これは、クエリ結果の var_dump です。

array (size=1)
    'route' => string 'LINESTRING(-25.3233034167988 -57.640113830566406,-25.3229348965009 -57.64023184776306,-25.322653656571582 -57.63954520225525,-25.323410093517822 -57.63928771018982,-25.3229058027454 -57.6378607749939,-25.322973688164012 -57.63678789138794,-25.323371301994506 -57.63360142707825,-25.322003892857673 -57.633676528930664,-25.31995759927745 -57.633376121520996,-25.319336915717006 -57.63331174850464,-25.317988857651912 -57.63302206993103,-25.317377862364236 -57.63294696807861,-25.317688209562228 -57.62954592704773'... (length=4354)

目的は、次のような配列を持つことです: route:

array (size=4354)
    0 => { x=> '-25.3233034167988', y=> '-57.640113830566406'}
    1 => { x=> '-25.3229348965009 ', y=> '-57.64023184776306'}

等々

nickb コードを使用すると、結果は次のようになります。

array (size=112)
  0 => 
    array (size=2)
      'x' => string '-25.3233034167988' (length=17)
      'y' => string '-57.640113830566406' (length=19)
  1 => 
    array (size=2)
      'x' => string '-25.3229348965009' (length=17)
      'y' => string '-57.64023184776306' (length=18)
  2 => 
    array (size=2)
      'x' => string '-25.322653656571582' (length=19)
      'y' => string '-57.63954520225525' (length=18)

完全

4

3 に答える 3

1

簡単な文字列操作を行い、次の配列を作成しstr_getcsv()ます。

$str = $array['route']; // Get the string from the array
// Get rid "LINESTRING(" and trailing ")"
$str = substr( $str, 11, (strlen( $str) - 1) - 11); 

x次に、次のようにキーとyキーを入力するだけです。

// Form the objective array:
$objective = array();
foreach( str_getcsv( $str) as $k => $v) {
    list( $x, $y) = explode( ' ', $v);
    $objective[$k]['x'] = $x;
    $objective[$k]['y'] = $y;
}

このデモから、これが出力されることがわかります。

Array ( [0] => Array ( [x] => -25.3233034167988 [y] => -57.640113830566406 ) ... etc ...)
于 2013-05-28T14:22:53.150 に答える
1

文字列を解析するより効果的な方法だと思います。

$route = 'LINESTRING(-25.3233034167988 -57.640113830566406,-25.3229348965009 -57.64023184776306,-25.322653656571582 -57.63954520225525)';
preg_match_all('/([0-9.\-]+) ([0-9.\-]+)/', $route, $matches);

$result = array_map(function($x, $y)
    {
    return ['x' => $x, 'y' => $y];
    }, $matches[1], $matches[2]);

var_dump($result);
于 2014-09-18T08:16:37.857 に答える
0

分解関数を 2 回使用して新しい配列を作成し、それをループして期待どおりにキーを割り当てることができると思います

$string = array('route' => 'LINESTRING(-25.3233034167988 -57.640113830566406,-25.3229348965009 -57.64023184776306,-25.322653656571582 -57.63954520225525,-25.323410093517822 -57.63928771018982,-25.3229058027454 -57.6378607749939,-25.322973688164012 -57.63678789138794,-25.323371301994506 -57.63360142707825,-25.322003892857673 -57.633676528930664,-25.31995759927745 -57.633376121520996,-25.319336915717006 -57.63331174850464,-25.317988857651912 -57.63302206993103,-25.317377862364236 -57.63294696807861,-25.317688209562228 -57.62954592704773');
$new_array = array();
$final_array = array();
foreach($string as $data)
{
    $array = explode(',', $data);
    foreach($array as $value)
    {
        $new_array []= explode(' ', str_replace('LINESTRING(', '', $value));
    }

    $array_key = array('x', 'y');
    foreach($new_array as $val)
    {
        $final_array []= (array_combine($array_key, $val));
    }
}

var_dump($final_array);

これは出力されます

array (size=13)
  0 => 
    array (size=2)
      'x' => string '-25.3233034167988' (length=17)
      'y' => string '-57.640113830566406' (length=19)
  1 => 
    array (size=2)
      'x' => string '-25.3229348965009' (length=17)
      'y' => string '-57.64023184776306' (length=18)
  2 => 
    array (size=2)
      'x' => string '-25.322653656571582' (length=19)
      'y' => string '-57.63954520225525' (length=18)
  3 => 
    array (size=2)
      'x' => string '-25.323410093517822' (length=19)
      'y' => string '-57.63928771018982' (length=18)
  4 => 
    array (size=2)
      'x' => string '-25.3229058027454' (length=17)
      'y' => string '-57.6378607749939' (length=17)
  5 => 
    array (size=2)
      'x' => string '-25.322973688164012' (length=19)
      'y' => string '-57.63678789138794' (length=18)
     //and so on
于 2013-05-28T14:34:17.170 に答える