Sponsored Content
Top Forums Shell Programming and Scripting Parse a string in XML file using shell script Post 302145823 by matrixmadhan on Thursday 15th of November 2007 10:12:56 AM
Old 11-15-2007
Here is the updated code,

the reason why it didn't work in the first phase is that, input format was different, there were no 'line feeds' in the sample file provided.

Now it should work!

Let us know how it proceeds!

Code:
#! /opt/third-party/bin/perl

my $c = 0;

open(FILE, "<", "sample.txt");

while(<FILE>) {
  chomp;
    my @arr = split(/></);
    foreach (@arr) {
    if( /xml version/ ) {
      $c++;
      print "\n";
    }
    if( />/ && /</ ) {
      if( $c == 1 ) {
        s/(.*)>(.*)<.*$/\1|\2/;
        my($tmp1, $tmp2) = split(/\|/);
        $data .= (" " . $tmp2);
        printf "%s ", $tmp1;
      }
      else {
        s/(.*)>(.*)<.*$/\2/;
        printf "%s ", $_;
      }
    }
  }
  print "\n";
  print "$data\n" if( /xml version/i );
}

close(FILE);

exit 0

 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Parse String in XML file

Hello All, I am new to this and I need to parse an XML file. Here's the XML Input File: <Report version="1.2"> <summary fatals="0" testcases="1" expected_fails="0" unexpected_passes="0" warnings="9" tests="21" errors="0" fails="1" passes="20" /> <testresult... (4 Replies)
Discussion started by: racbern
4 Replies

2. Shell Programming and Scripting

Need help in creating a Unix Script to parse xml file

Hi All, My requirement is create an unix script to parse the xml file and display the values of the Elements/value between the tags on console. Like say, I would like to fetch the value of errorCode from the below xml which is 'U007' and display it. Can we use SED command for this? I have tried... (10 Replies)
Discussion started by: Anil.Wmg
10 Replies

3. Shell Programming and Scripting

Parse XML file into CSV with shell?

Hi, It's been a few years since college when I did stuff like this all the time. Can someone help me figure out how to best tackle this problem? I need to parse a file full of entries that look like this: <eq action="A" sectyType="0" symbol="PGR" exch="CA" curr="VEF" sess="NORM"... (7 Replies)
Discussion started by: Pcushing
7 Replies

4. Shell Programming and Scripting

regex/shell script to Parse through XML Records

Hi All, I have been working on something that doesn't seem to have a clear regex solution and I just wanted to run it by everyone to see if I could get some insight into the method of solving this problem. I have a flat text file that contains billing records for users, however the records... (5 Replies)
Discussion started by: Jerrad
5 Replies

5. Shell Programming and Scripting

Parse XML file in shell script

Hi Everybody, I have an XML file containing some data and i want to extract it, but the specific issue in my file is that the data is repeated some times like the following example : <section1> <subsection1> X=... Y=... Z=... <\subsection1> <subsection2> X=... Y=... Z=...... (2 Replies)
Discussion started by: yassine
2 Replies

6. Shell Programming and Scripting

Shell script (not Perl) to parse xml with awk

Hi, I have to make an script according to these: - I have couples of files like: xxxxxxxxxxxxx.csv xxxxxxxxxxxxx_desc.xml - every xml file has diferent fields, but keeps this format: ........ <defaultName>2011-02-25T16:43:43.582Z</defaultName> ........... (2 Replies)
Discussion started by: Pluff
2 Replies

7. Shell Programming and Scripting

How to parse xml file in variable-string?

In the wake of the post: how-parse-following-xml-file Thank you for the very useful chakrapani response 302355585-post4 ! A close question. How to pass a file to xmllint in variable? For example, let it be: NEARLY_FILE='<?xml version="1.0" encoding="iso-8859-1"?><html><set label="09/07/29"... (0 Replies)
Discussion started by: OleM2k
0 Replies

8. Shell Programming and Scripting

How to Parse the XML data along with the URL in Shell Script?

Hi, Can anybody help to solve this. I want to parse some xmldata along with the URL in the Shell. I'm calling the URL via the curl command Given below is my shell script file export... (7 Replies)
Discussion started by: Megala
7 Replies

9. Shell Programming and Scripting

Using shell command need to parse multiple nested tag value of a XML file

I have this XML file - <gp> <mms>1110012</mms> <tg>988</tg> <mm>LongTime</mm> <lv> <lkid>StartEle=ONE, Desti = Motion</lkid> <kk>12</kk> </lv> <lv> <lkid>StartEle=ONE, Source = Velocity</lkid> <kk>2</kk> </lv> <lv> ... (3 Replies)
Discussion started by: NeedASolution
3 Replies

10. Shell Programming and Scripting

Parse xml in shell script and extract records with specific condition

Hi I have xml file with multiple records and would like to extract records from xml with specific condition if specific tag is present extract entire row otherwise skip . <logentry revision="21510"> <author>mantest</author> <date>2015-02-27</date> <QC_ID>334566</QC_ID>... (12 Replies)
Discussion started by: madankumar.t@hp
12 Replies
maptool(1)							   USER COMMANDS							maptool(1)

NAME
maptool - parse osm textfile and convert to Navit binfile format SYNOPSIS
For OSM XML data: bzcat planet.osm.bz2 | maptool mymap.bin [-h] [-2] [-5 <file>] [-6] [-a <level>] [-c] -[-d <connect string] [-e <phase>] [-i <file>] [-k] [-M] [-N] [-o] [-r <file>] [-s <phase>] [-S <size>] [-w] [-W] [-U] [-z <level>] For OSM Protobuf/PBF data: maptool --pro- tobuf -i planet.osm.pbf planet.bin [-h] [-2] [-5 <file>] [-6] [-a <level>] [-c] [-e <phase>] [-i <file>] [-k] [-M] [-N] [-o] [-P] [-r <file>] [-s <phase>] [-S <size>] [-w] [-W] [-U] [-z <level>] DESCRIPTION
maptool parses osm textfile and converts it to Navit binfile format OPTIONS
-h (--help) display a short help message -2 (--dowai2poi) convert ways and polygons to POIs when applicable -4 (--md5) set file where to write md5 sum -6 (--64bit) set zip 64 bit compression -a (--attr-debug-level) <level> control which data is included in the debug attribute -c (--dump-coordinates) dump coordinates after phase 1 -d (--db) <connect string> get osm data out of a postgresql database with osm simple scheme and given connect string -e (--end) <phase> end at specified phase -i (--input-file) <file> specify the input file name (OSM), overrules default stdin -k (--keep-tmpfiles) do not delete tmp files after processing. useful to reuse them -N (--nodes-only) process only nodes -o (--coverage) converts every street to street_converage, resulting in a big fat black line. You can overlay this map with another vector map or image map, and every street you will still see is missing in the -o map -P (--protobuf) input file is protobuf -r (--rule-file) <file> read mapping rules from specified file -s (--start) <phase> start at specified phase -S (--slice-size) <phrase> defines the amount of memory to use, in bytes. Default is 1GB -w (--dedupe-ways) ensure no duplicate ways or nodes. useful when using several input files -W (--ways-only) process only ways -U (--unknown-country) add objects with unknown country to index -z (--compression-level) <level> set the compression level BUGS
Should you find one, please report it : http://trac.navit-project.org AUTHOR
The navit Team - http://www.navit-project.org SEE ALSO
navit(1) $Revision$ $Date$ maptool(1)
All times are GMT -4. The time now is 08:59 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy