From f403b2c124e2fe5fad9287bbc4f1d8d2cd12a5ee Mon Sep 17 00:00:00 2001 From: Daniel Friesel Date: Sun, 22 Dec 2019 14:38:03 +0100 Subject: Add IRIS XML <-> JSON DB comparison script. Does not update DB yet. --- share/xml2json | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100755 share/xml2json diff --git a/share/xml2json b/share/xml2json new file mode 100755 index 0000000..0c4800b --- /dev/null +++ b/share/xml2json @@ -0,0 +1,51 @@ +#!/usr/bin/env perl + +use strict; +use warnings; +use 5.010; + +use File::Slurp qw(read_file write_file); +use JSON; +use XML::LibXML; + +my $json_str = read_file('stations.json'); +my $stations = JSON->new->utf8->decode($json_str); +@{$stations} = sort { $a->{name} cmp $b->{name} } @{$stations}; + +my $xml_str = read_file('stations.xml'); +my $tree = XML::LibXML->load_xml( string => $xml_str ); + +for my $station ( $tree->findnodes('//station') ) { + my $name = $station->getAttribute('name'); + my $eva = $station->getAttribute('eva'); + my $ds100 = $station->getAttribute('ds100'); + + for my $j_station ( @{$stations} ) { + my $j_name = $j_station->{name}; + my $j_ds100 = $j_station->{ds100}; + my $j_eva = $j_station->{eva}; + if ( $j_ds100 eq $ds100 and $j_name ne $name ) { + printf( "%8s has been renamed: %30s -> %30s\n", + $ds100, $j_name, $name ); + last; + } + elsif ( $j_eva == $eva and $j_name ne $name ) { + printf( "%d mismatch: (%s -> %s), (%s -> %s)\n", + $eva, $j_name, $name, $j_ds100, $ds100 ); + last; + } + elsif ( $j_name eq $name and $j_ds100 ne $ds100 ) { + printf( "%30s has been recoded: %8s -> %8s\n", + $name, $j_ds100, $ds100 ); + last; + } + elsif ( $j_name eq $name and $j_eva != $eva ) { + printf( "%30s has been recoded: %d -> %d\n", $name, + $j_eva != $eva ); + last; + } + } +} + +my $json_out = JSON->new->utf8->canonical->pretty->encode($stations); +write_file( 'stations.json', $json_out ); -- cgit v1.2.3