Sponsored Content
Top Forums Shell Programming and Scripting sed cannot execute [Argument list too long] Post 302897803 by galaxy_rocky on Wednesday 16th of April 2014 06:49:14 AM
Old 04-16-2014
Hi ygemici,

$1F is the first field from the first line of the input file. Similarly $2F is the the second field from the first line of input file. This should loop for all the lines in the input file. Totally there are 13 fields in the input file. That is the reason i am using 13 awk commands!

My sample input file looks like below:

Code:
SG0010001;TRANSACTION;24:.ENTRY;31-MAR-14;SG0010001;123456789.020001;TRANSACTION;123;Metal XYZ Xy;N/A;N/A;N/A;CD_VALUE_TST;
SG0010001;TRANSACTION;24:.ENTRY;31-MAR-14;SG0010001;789456123.020001;TRANSACTION;123;Metal XYZ Xy;N/A;N/A;N/A;CD_VALUE_TST;
SG0010001;TRANSACTION;24:.ENTRY;31-MAR-14;SG0010001;147852369.040001;TRANSACTION;123;Metal XYZ Xy;N/A;N/A;N/A;CD_VALUE_TST;
SG0010001;TRANSACTION;24:.ENTRY;31-MAR-14;SG0010001;159753456.020001;TRANSACTION;123;Metal XYZ Xy;N/A;N/A;N/A;CD_VALUE_TST;

And my sample expected output is :

Code:
<Worksheet ss:Name="CD_VALUE_TST">
<Table>
<Row>
<Cell><Data ss:Type="String">EC</Data></Cell>
<Cell><Data ss:Type="String">TARGET_TRANSLATION</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_FILE_NAME</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_EFF_FROM</Data></Cell>
<Cell><Data ss:Type="String">CO_CODE</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_ID</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_CODE_SET_1</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_FIELD_1</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_FIELD_1_DESC</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_CODE_SET_2</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_FIELD_2</Data></Cell>
<Cell><Data ss:Type="String">SOURCE_FIELD_2_DESC</Data></Cell>
<Cell><Data ss:Type="String">TARGET_CODE_SET</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">SG0010001</Data></Cell>
<Cell><Data ss:Type="String">TRANSACTION</Data></Cell>
<Cell><Data ss:Type="String">24:.ENTRY</Data></Cell>
<Cell><Data ss:Type="String">31-MAR-14</Data></Cell>
<Cell><Data ss:Type="String">SG0010001</Data></Cell>
<Cell><Data ss:Type="String">123456789.020001</Data></Cell>
<Cell><Data ss:Type="String">TRANSACTION</Data></Cell>
<Cell><Data ss:Type="String">123</Data></Cell>
<Cell><Data ss:Type="String">Metal XYZ Xy</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">CD_VALUE_TST</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">SG0010001</Data></Cell>
<Cell><Data ss:Type="String">TRANSACTION</Data></Cell>
<Cell><Data ss:Type="String">24:.ENTRY</Data></Cell>
<Cell><Data ss:Type="String">31-MAR-14</Data></Cell>
<Cell><Data ss:Type="String">SG0010001</Data></Cell>
<Cell><Data ss:Type="String">789456123.020001</Data></Cell>
<Cell><Data ss:Type="String">TRANSACTION</Data></Cell>
<Cell><Data ss:Type="String">123</Data></Cell>
<Cell><Data ss:Type="String">Metal XYZ Xy</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">CD_VALUE_TST</Data></Cell>
</Row>
</Table>
</Worksheet>

Basically the fields in the input value are seperated by ";". Based on the number of records in the input file, there should be corresponing entries in the output file.
Please help on this issue.

Regards,

Last edited by galaxy_rocky; 04-16-2014 at 07:56 AM.. Reason: code tag
 

10 More Discussions You Might Find Interesting

1. UNIX for Dummies Questions & Answers

Argument list too long - SSH

Hi I executed the code for file in `ls pdb*.ent` do new_name=`echo $file | sed 's/^pdb//;s/.ent/.txt/'` mv $file $new_name done Its giving error at ' ls pdb*.ent' argument list too long i have around 150000 entries please help Thank you (6 Replies)
Discussion started by: empyrean
6 Replies

2. Shell Programming and Scripting

Argument too long list error

I have a wrote a script which consits of the below line.. Below of this script I'm getting this error "ksh: /usr/bin/ls: arg list too long" The line is log_file_time=`ssh -i $HOME/.ssh/id_rsa -q $i ls -lrt /bp/karthik/test/data/log/$abc*|tail -1|awk '{print $8}'` And $abc alias is as "p |... (1 Reply)
Discussion started by: 22karthikreddy
1 Replies

3. UNIX for Dummies Questions & Answers

Argument list too long for Sed command

Hi guys Following command results in sed -i 's/#/\\#/g' /home/test/sqlstents* -bash: /bin/sed: Argument list too long Please help me solve it.. is there any other way i can do this?.. thanks (4 Replies)
Discussion started by: depakjan
4 Replies

4. Shell Programming and Scripting

Argument list too long problem

I have a huge set of files (with extension .common) in my directory around 2 million. When I run this script on my Linux with BASH, I get /bin/awk: Argument list too long awk -F'\t' ' NR == FNR { a=NR } NR != FNR { sub(".common", "", FILENAME) print a, FILENAME, $1 } '... (1 Reply)
Discussion started by: shoaibjameel123
1 Replies

5. Shell Programming and Scripting

Argument list too long for date command

Dear Friends, The following script processes a 14508 lines log file. #!/bin/sh while read line do d=`sed 's/* - * \*\/*\/* *\)\] .*/\1/' | tr '/' ' ' | sed 's/\(*\):\(*\)/\1 \2/'` y=`date -d "${d}" "+%Y%m%d%H%M%S"` echo "${y}" done While running the above script, I am... (4 Replies)
Discussion started by: tamil.pamaran
4 Replies

6. Shell Programming and Scripting

Argument list too long!!

Dear Experts, I have a list of 10K files in a directory. I am not able to execute any commands lile ls -lrt, awk, sed, mv, etc........ I wanna execute below command and get the output. How can I achieve it?? Pls help. root# awk -F'|' '$1 == 1' file_20120710* | wc -l /bin/awk: Argument list... (2 Replies)
Discussion started by: Naga06
2 Replies

7. Shell Programming and Scripting

grep : Argument list too long

Hi, i am having some trouble with the below command, can some one suggest me the better way to do it. grep -l 'ReturnCode=1' `find $Log -newer /tmp/Failed.tmp -print | xargs ls -ld | egrep SUB | egrep -ve 'MTP' -ve 'ABC' -ve 'DEF' -ve 'JKL' -ve 'XYZ' | awk '{print $9}'` > $Home1 Its... (2 Replies)
Discussion started by: Prateek007
2 Replies

8. Shell Programming and Scripting

mv : Argument list too long

Hi I am using find command -- find "directory1" -type f | xargs -i mv {} "directory2" to avoid above argument list too long problem. But, issue i am facing is directory1 is having subdirectories due to this i am facing directory traversal problem as i dont want to traverse subdirectories... (9 Replies)
Discussion started by: VSom007
9 Replies

9. UNIX for Advanced & Expert Users

Argument list too long w/ sed

Hi all, I am using GNU sed (named gsed under macports) in OSX. I have a directory with a series of files named pool_01.jpg through pool_78802.jpg. I am trying to use this command to rename the files to their checksum + extension. md5sum * | gsed -e 's/\(*\) \(.*\(\..*\)\)$/mv -v \2 \1\3/e' ... (3 Replies)
Discussion started by: openthomas
3 Replies

10. Shell Programming and Scripting

Argument list too long

Hi Team, Here's the situation. I have approximately 300000 to 500000 jpg files in /appl/abcd/work_dir mv /appl/abcd/work_dir /appl/abcd/process_dir The above move command will work if the jpg files count is close to 50000 (not sure). If the count is less this mv command holds good. But if... (14 Replies)
Discussion started by: kmanivan82
14 Replies
All times are GMT -4. The time now is 12:40 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy