tr '[a-z]\-[a-z]' need help with replace


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting tr '[a-z]\-[a-z]' need help with replace
# 1  
Old 08-05-2010
tr '[a-z]\-[a-z]' need help with replace

HI experts....

i need to know if there is a way of appending some text to an existing string using "tr" command....i know it can be done easily using awk and sed....


but i need to know if there is way we can do that using tr command

so

the output is in the format

somename
xname
zname

i want to output in the format

somename, a
xname, a
zname, a

so i just want to append ",a" to an existing string

I have to do this only using tr command please advice.

thanks
# 2  
Old 08-05-2010
You would/could probably never do what you describe with tr. tr works on a per character basis, not a group of characters (a string). Plus tr means translate, that means:
'change one character to another' So, tr works one just one single character at a time, not two.

ways to do what you ask
Code:
# one way
while read rec
do
   echo "$rec" ", a"
done < inputfile > outputfile
# another way
awk '{print $0 ", a" } ' inputfile > outputfile
# sed
sed 's/[a-zA-z0-9 ]$/&, a/'  inputfile > outputfile

This User Gave Thanks to jim mcnamara For This Post:
# 3  
Old 08-05-2010
An in-place option:
Code:
printf '1,$s/$/, a/\nw\nq\n' | ed -s data

# 4  
Old 08-05-2010
MySQL

Code:
# ./justdoit
somename,a
xname,a
zname,a


Code:
 
for myval in `cat infile`
  do
   echo $(printf "$(echo "$myval")\na"|tr '\n' ',') >> mytemp
  done
more mytemp

# 5  
Old 08-05-2010
Quote:
Originally Posted by ygemici
Code:
# ./justdoit
somename,a
xname,a
zname,a


Code:
 
for myval in `cat infile`
  do
   echo $(printf "$(echo "$myval")\na"|tr '\n' ',') >> mytemp
  done
more mytemp

Could work, but it's not the most efficient way Smilie
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. UNIX for Beginners Questions & Answers

awk script to extract a column, replace one of the header and replace year(from ddmmyy to yyyy)

I have a csv which has lot of columns . I was looking for an awk script which would extract a column twice. for the first occurance the header and data needs to be intact but for the second occurance i want to replace the header name since it a duplicate and extract year value which is in ddmmyy... (10 Replies)
Discussion started by: Kunalcurious
10 Replies

2. UNIX for Dummies Questions & Answers

How can I replace the lines that start with a star and replace it with numbers start from 1?

I need to replace the (*) in the fist of a list with numbers using sed for example > this file contain a list * linux * computers * labs * questions to >>>> this file contain a list 1. linux 2. computers 3. labs 4. questions (7 Replies)
Discussion started by: aalbazie
7 Replies

3. Shell Programming and Scripting

Replace dashes positions 351-357 & 024-043 with 0 & replace " " if exis with 04 at position 381-382

I need to replace dashes (i.e. -) if present from positions 351-357 with zero (i.e. 0), I also need to replace dash (i.e “-“) if present between position 024-043 with zero (i.e. 0) & I replace " " (i.e. 2 space characters) if present at position 381-382 with "04". Total length of record is 413.... (11 Replies)
Discussion started by: lancesunny
11 Replies

4. Shell Programming and Scripting

How to replace

Here is my file content age=12 age=34 age=54 age=23 Hello world. This is the age result I am getting. To day date is 23-02-2010. From the above content I have to replace all the values after 'age=*' to age=24. How to do it. (1 Reply)
Discussion started by: brahma
1 Replies

5. Shell Programming and Scripting

awk - replace number of string length from search and replace for a serialized array

Hello, I really would appreciate some help with a bash script for some string manipulation on an SQL dump: I'd like to be able to rename "sites/WHATEVER/files" to "sites/SOMETHINGELSE/files" within the sql dump. This is quite easy with sed: sed -e... (1 Reply)
Discussion started by: otrotipo
1 Replies

6. Shell Programming and Scripting

Replace Help

Hi, djfksdjk)))) kmmm jfdfjk)))) I want to replace the first ')' after kmmm with #. The output would be djfksdjk)))) exists jfdfjk#))) Can anyone help on this? (3 Replies)
Discussion started by: javeed7
3 Replies

7. Shell Programming and Scripting

replace

hi i have input file in this format E102|0|1-23-1994|0|12-5-1994|E003|A|10450|charan,devupalli|5000 how to convert this into outfile E102,0,1-23-1994,0,12-5-1994,E003,A,10450,charan,devupalli,5000 i wann the output in excel sheet.........that is why i am converting into csv.. but i have... (6 Replies)
Discussion started by: charandevu
6 Replies

8. Shell Programming and Scripting

replace last / by |

Hi: I want to write a Kshell script which will replace last / by |. eg: /home/apps/test/document should be replaced as /home/apps/test|document. The length of the string is not constant. Thanks, Ash (6 Replies)
Discussion started by: naikaa
6 Replies

9. Shell Programming and Scripting

How to replace into Vi

Ravi . Pawan 19.23 sanjeeva . I want to replace '.' into 'NULL' not the dot between 19.23 .. only single dots to NULL how to do replacement after opening file in Vi (5 Replies)
Discussion started by: ravi.sadani19
5 Replies

10. UNIX for Dummies Questions & Answers

How to replace ??

Hi all, I have a file with the following data. E01011U, ,E11, , , ,0 E03012U, ,E14, , , ,0 E02013U, ,E25, , , ,0 I want to change it to ('E01-01-1-U','E11' ); ('E03-01-2-U','E14' ); ('E02-01-3-U','E25' ); Please let me know about it .Thanks in advance. (10 Replies)
Discussion started by: preethgideon
10 Replies
Login or Register to Ask a Question