2

我有一个带有 5.5mb 经度纬度数据的 JavaScript 对象文件,我想在 Perl 中打开它,这样我就可以应用一个粗略的细节减少算法,然后用减少的数据集保存一个新的目标文件。为了减少细节,我使用了一个 for 循环,它只需要每 20 个 long/lat 对。

我可以在 javascript 中执行此操作,但这需要我复制/粘贴每个坐标集并一次在其上运行我的 JavasSript。

然后我想也许我可以获取每组坐标并将它们放入 SQL 数据库,但这似乎是一种粗略的方法。并移动大量数据。

我认为 Perl 是更好的选择之一,它可以在服务器上完成。

我可以打开文件:

#!/usr/bin/perl

# open file
 open(FILE, "reduced_object_latlng.js") or die("Unable to open file");

# read file into an array
@data = <FILE>;

# close file 
close(FILE);

# print file contents
foreach $line (@data)
{
    print $line;
}

该对象遵循以下设计:

var paths = {
    mayo: {
        name: 'Mayo',
        colour: 'green',
        coordinates: '-9.854892,53.76898 -9.853634,53.769338 -9.85282,53.769387 -9.851981,53.769561 -9.850952,53.769508 -9.850129,53.769371 -9.849136,53.769171 **data**' 
    },
    galway: {
        name: 'Galway',
        colour: 'purple',
        coordinates: '**data**;
    }
}; //etc.

为了说明我如何减少上述数据,我的 javascript 版本从一个文件加载var coords = "*data*"

coords = coords.split(" ");
var path = [];
    var output="";
    document.getElementById("map_canvas").innerHTML = "";
for (var i = 0; i < coords.length; i++) {
        if (i%20==0)
        {
            var coord = coords[i].split(",");
            output += coord[0]+","+coord[1]+" ";
        }
}
document.getElementById("map_canvas").innerHTML = output;

我读过一些建议我将其转换为 JSON,我不确定是否需要这样做。而不是编写纯文本处理程序,有没有办法将文件作为对象加载?


我被困住了,所以我这样做了:

var outputobject = 'var paths = {';
    for (property in copypaths) {
        outputobject += property + ': { ';
        outputobject += "name: '" + copypaths[property].name+"',";
        outputobject += "colour: '"+ copypaths[property].colour+"',";

        var reducedoutput="";
        var coord = copypaths[property].coordinates.split(" ");
        for (var i = 0; i < coord.length; i++) {
            if (i%20==0)
            {
                var coords = coord[i].split(",");
                reducedoutput += coords[0]+","+coords[1]+" ";
            }
        }   
        outputobject += "coordinates: '"+ reducedoutput+"'},";
    }
    outputobject += "};";
    document.getElementById("reduced").innerHTML = outputobject;

它仍然涉及复制/粘贴和删除最后一个,. 谢谢@Oleg V. Volkov,当我在本周晚些时候有更多时间时,我会看看你提出的方法。

4

2 回答 2

3

只需剥离前导 JavaScript,这样您就可以使用裸键获得几乎正确的 JSON,并使用设置为 true 值的JSON/JSON::PP instanceallow_barekey来解码结果字符串。

于 2012-08-06T13:49:54.213 回答
1

使用JSON是您最好的选择。它具有允许您解码不太严格的 JSON 语法的选项,您将需要

  • allow_singlequote允许单引号和双引号字符串

  • allow_barekey允许全字母数字哈希键根本没有引号

  • decode_prefix在数据结束后忽略垃圾

  • relaxed为了好运

下面的程序将 JSON 解码为 Perl 结构,提取mayo条目的坐标字符串,并将值成对打印出来。

请注意,我删除了分号并在末尾添加了一个引号,coordinates: '**data**;因为我认为这是一个错误,而不是实际的 JavaScript 数据

use strict;
use warnings;

use JSON -support_by_pp;

my $json = JSON->new->relaxed->allow_singlequote->allow_barekey;

my $data = do {
  local $/;
  <DATA>;
};

my ($hash) = $json->decode_prefix($data =~ /(\{.*)/s);

my @coords = $hash->{mayo}{coordinates} =~ /[-0-9.]+/g;

printf "%f %f\n", splice @coords, 0, 2 while @coords;

__DATA__
var paths = {
    mayo: {
        name: 'Mayo',
        colour: 'green',
        coordinates: '-9.854892,53.76898 -9.853634,53.769338 -9.85282,53.769387 -9.851981,53.769561 -9.850952,53.769508 -9.850129,53.769371 -9.849136,53.769171 **data**' 
    },
    galway: {
        name: 'Galway',
        colour: 'purple',
        coordinates: '**data**'
    }
}; //etc.

输出

-9.854892 53.768980
-9.853634 53.769338
-9.852820 53.769387
-9.851981 53.769561
-9.850952 53.769508
-9.850129 53.769371
-9.849136 53.769171
于 2012-08-06T15:55:58.247 回答