To replace the value of the column in a fixed width file


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting To replace the value of the column in a fixed width file
# 1  
Old 08-02-2013
To replace the value of the column in a fixed width file

I have a fixed with file with header & trailer length having the same length of the detail record file.

The details record length of this file is 24, for Header and Trailer the records will be padded with spaces to match the record length of the file
Currently I am adding 3 spaces in header and 6 spaces in trailer to match with detail record length

current value of my header is
Column Name Data length
---------- ----------
Code:
A        1
B        2
C        2
D        8
E        8

current value of my trailer is

Column Name Data length
---------- ----------
Code:
A        1
B        2
C        15

My requirement is to change the value of the second column(Column B) from xx to yyy both in header and trailer.
After this change I should have only two spaces in header and 5 spaces in trailer

Can some one help here please

---------- Post updated at 05:03 AM ---------- Previous update was at 02:43 AM ----------

I have a fixed with file with header & trailer length having the same length of the detail record file.

The details record length of this file is 24, for Header and Trailer the records will be padded with spaces to match the record length of the file
Currently I am adding 3 spaces in header and 6 spaces in trailer to match with detail record length

current value of my header is

Code:
Column Name  Data length
----------   ----------
A        1
B        2
C        2
D        8
E        8

current value of my trailer is

Code:
Column Name  Data length
----------   ----------
A        1
B        2
C        15

My requirement is to change the value of the second column(Column B) from xx to yyy both in header and trailer.
After this change I should have only two spaces in header and 5 spaces in trailer

Last edited by Franklin52; 08-02-2013 at 04:48 AM.. Reason: Please use code tags
# 2  
Old 08-02-2013
I don't fully understand.
If you need a fixed record size, use printf:
Code:
awk '(NR<=2) {printf "%-24s\n",$0; next} ($1=="B") {printf "%-13s%-11s\n",$1,$2}' file

To change a certain value on the fly, you can use
Code:
{
awk '(NR<=2) {printf "%-24s\n",$0; next} ($1=="B") {$2="yyy"} {printf "%-13s%-11s\n",$1,$2}' header
cat detail
awk '(NR<=2) {printf "%-24s\n",$0; next} ($1=="B") {$2="yyy"} {printf "%-13s%-11s\n",$1,$2}' trailer
} > newfile

# 3  
Old 08-02-2013
Thanks for the reply.
Let me explain the requirement again

I have a file with header and trailer which is fixed width
Header is having five columns & trailer is having 3 columns.The respective length of each column I have mentioned below.

Code:
Column Name  Data length
----------   ----------
A        1
B        2
C        2
D        8
E        8

current value of my trailer is 

Column Name  Data length
----------   ----------
A        1
B        2
C        15

sample records for header :-

Code:
1cc  12345   43434

I need to replace the above sample record second column value with yyy.i.e from cc to yyy.

Code:
1yyy  12345  43434

# 4  
Old 08-02-2013
So you need to split the data into 3 (x , xx and xxxxxxxxxxxxxxx) overwriting the second potion with "yyy" ?

Code:
perl -ne 'print substr($_ ,0,1),"yyy",subsr($_,3)' file_name

---------- Post updated at 02:53 PM ---------- Previous update was at 02:53 PM ----------

So you need to split the data into 3 (x , xx and xxxxxxxxxxxxxxx) overwriting the second potion with "yy" ?

Code:
perl -ne 'print substr($_ ,0,1),"yy",subsr($_,3)' file_name

# 5  
Old 08-02-2013
Thank you..

I tried but its not working..Mine is a unix machine, In which pearl command is not working
# 6  
Old 08-02-2013
This replaces position 2-3 with yyy, shifting the remainder by +1
Code:
sed 's/\(.\{1\}\)../\1yyy/'

This User Gave Thanks to MadeInGermany For This Post:
# 7  
Old 08-03-2013
Thanks a lot.Its working fine.

if possible can you please tell me how to replace only the header & trailer of the file rest of the records need to be the same

---------- Post updated 08-03-13 at 12:48 AM ---------- Previous update was 08-02-13 at 07:17 PM ----------

Code:
sed 's/\(.\{1\}\)../\1yyy/'

This command is actually replacing the value of all the records in the file.But I need to replace the value of header & trailer only .Please some one help here
Login or Register to Ask a Question

Previous Thread | Next Thread

9 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Search and replace value based on certain conditions in a fixed width file

Hi Forum. I tried searching for a solution using the internet search but I haven't been able to find any solution for what I'm trying to accomplish. I have a fixed width column file where I need to search for any occurrences of "D0" in col pos.#1-2, 10-11, 20-21 and replaced it with "XD". ... (2 Replies)
Discussion started by: pchang
2 Replies

2. Shell Programming and Scripting

Replace using awk on fixed width file.

All, I used to use following command to replace specific location in a fixed width file. Recently looks like my command stopped working as intended. We are on AIX unix. awk 'function repl(s,f,t,v) { return substr(s,1,f-1) sprintf("%-*s", t-f+1, v) substr(s,t+1) } NR<=10 {... (3 Replies)
Discussion started by: pinnacle
3 Replies

3. Shell Programming and Scripting

Print column details from fixed width file using awk command

hi, i have a fixed width file with multiple columns and need to print data using awk command. i use: awk -F "|" '($5 == BH) {print $1,$2,$3}' <non_AIM target>.txt for a delimiter file. but now i have a fixed width file like below: 7518 8269511BH 20141224951050N8262 11148 8269511BH... (5 Replies)
Discussion started by: kcdg859
5 Replies

4. UNIX for Dummies Questions & Answers

Replace the unexpected newline char with space in a Fixed width file

Input eg: Ouput Expected. The #rd line had the unexpted new line, which need to be replaced with space. I was planing to go with checking the length of each line using awk and if the length is less than the defeined limit, (12 in above case) will replace the newline with space. ... (5 Replies)
Discussion started by: deepakwins
5 Replies

5. Shell Programming and Scripting

How to split a fixed width text file into several ones based on a column value?

Hi, I have a fixed width text file without any header row. One of the columns contains a date in YYYYMMDD format. If the original file contains 3 dates, I want my shell script to split the file into 3 small files with data for each date. I am a newbie and need help doing this. (14 Replies)
Discussion started by: bhanja_trinanja
14 Replies

6. UNIX for Dummies Questions & Answers

Remove duplicates based on a column in fixed width file

Hi, How to output the duplicate record to another file. We say the record is duplicate based on a column whose position is from 2 and its length is 11 characters. The file is a fixed width file. ex of Record: DTYU12333567opert tjhi kkklTRG9012 The data in bold is the key on which... (1 Reply)
Discussion started by: Qwerty123
1 Replies

7. Shell Programming and Scripting

Changing one column of delimited file column to fixed width column

Hi, Iam new to unix. I have one input file . Input file : ID1~Name1~Place1 ID2~Name2~Place2 ID3~Name3~Place3 I need output such that only first column should change to fixed width column of 15 characters of length. Output File: ID1<<12 spaces>>Name1~Place1 ID2<<12... (5 Replies)
Discussion started by: manneni prakash
5 Replies

8. Shell Programming and Scripting

edit entire column from a fixed-width file using awk or sed

Col1 Col2 Col3 Col4 12 Completed 08 0830 12 In Progress 09 0829 11 For F U 07 0828 Considering the file above, how could i replace the third column the most efficient way? The actual file size is almost 1G. I am... (10 Replies)
Discussion started by: tamahomekarasu
10 Replies

9. Shell Programming and Scripting

Comparing column of variable length anf fixed width file

Hi, I have two input files. File1: ID Name Place 1-234~name1~Newyork 1-34~name2~Boston 1-2345~name3~Hungary File1 is a variable length file where each column is seperated by delimitter "~". File2: ID Country 1-34<<11 SPACES>>USA<<7 spaces>> 1-234<<10 SPACES>>UK<<8... (5 Replies)
Discussion started by: manneni prakash
5 Replies
Login or Register to Ask a Question