I have the following file
Field1|Field2|Field3|Field4|Field5
a|b|c|d|e
1|2|3|4|5
z|y|x|w|v
I have a script which accepts two inputs
script.sh Field3 T
The script.sh would take the 'Field3' argument and based on that column number should replace the contents with 'T'.
[edit]
I tried the following suggestion from @Costas and ran into a problem. My file is like this:
MODULE_ColumnA~MODULE_ColumnB~MODULE_ColumnC~MODULE_ColumnD~MODULE_ColumnE
8.2~Y~N~~0
If I run the following script
cat <filename> | awk -F'~' -v p='MODULE_ColumnD' -v r='99' 'NR==1{for (i=1;i<=NF;i++) if($i==p)f=i;print;next}$f=r'
It replaces the value, but the delimiter is missing or replaced with space in the output as such:
MODULE_ColumnA~MODULE_ColumnB~MODULE_ColumnC~MODULE_ColumnD~MODULE_ColumnE
8.2 Y N 99 0
How do I get back the delimiter in the records?


3instead ofField3?awk -F'|' -v f=3 -v v=T 'FNR>1{$f=T}1' OFS='|' file