Reading a file line by line but...


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Reading a file line by line but...
# 1  
Old 10-15-2010
Reading a file line by line but...

I need to read a file line by line, but I am only interest in lines with a specific format.
I have a file that looks like the folowing, but I want to start where my database names start.

I want to start with the "mydb" line. None of my databases have the letters db in the name. This file can change in size since we check it and it gets a revision tagged at the top.

Code:
 
while read LINE
do
  DBNAME=`echo $LINE | cut -d ":" -f1`
done < $ORATAB


# Revision 1.1 2005-09-17 13:25:06-04 oracle
# Initial revision
#
#

# This file is used by ORACLE utilities. It is created by root.sh
# and updated by the Database Configuration Assistant when creating
# a database.
# A colon, ':', is used as the field terminator. A new line terminates
# the entry. Lines beginning with a pound sign, '#', are comments.
#
# Entries are of the form:
# $ORACLE_SID:$ORACLE_HOME:<N|Y>:
#
# The first and second fields are the system identifier and home
# directory of the database respectively. The third filed indicates
# to the dbstart utility that the database should , "Y", or should not,
# "N", be brought up at system boot time.
#
# Multiple entries with the same $ORACLE_SID are not allowed.
#
#
*:/opt/oracle/product/10120/mrca:N
*:/opt/oracle/product/10.1.0.3:N
*:/opt/oracle/product/10.1.0.3-devo:N
*:/opt/oracle/product/10.1.0.3_test:N
*:/opt/oracle/product/9206/dev/internal:N
*:/opt/oracle/product/9206/dev/id:N
*:/opt/oracle/product/9206/test/infrast:N
*:/opt/oracle/product/9206/test/id:N
*:/opt/oracle/product/9206/uat/id:N
mydb:/opt/oracle/product/10.2.0.4:N
# 2  
Old 10-15-2010
Something like this may help you:
Code:
dbName="mydb"

lineNo=`egrep -n '^'"${dbName}"'' ${ORATAB} | cut -f' -d":"`

if [ ${#lineNo} -eq 0 ]
then
	echo "ERROR: Database not present: [${dbName}]"
	exit 1
fi

tail -${lineNo} ${ORATAB} | \
while read oraTabLine
do
	<Do Something with the line>
done

# 3  
Old 10-16-2010
shouldn't it be
Code:
tail +${lineNo} ${ORATAB} | \

instead of
Code:
tail -${lineNo} ${ORATAB} | \

?

tail -<n> would take the <n> last lines of the file, whether tail +<n> would take from the <n>th line (from top) , until the end of the file
# 4  
Old 10-18-2010
If you want from top, use head -<n>

Regards.
# 5  
Old 10-18-2010
By using sed

To read 22nd line the file,
Code:
sed -n '22p' <file name>

# 6  
Old 10-18-2010
there are many database names. So there could be 10 lines with databases. The databases can have any names.

mydb
hisdb
thatdb
hello
goodbye

I think what I want to is grep for

:/opt/oracle/product/9206/test/infrast:N

then pipe it into another grep another grep that looks for lines that do no have a *

grep -i :/mypath/myfile | grep -i "*"

so grep -i will find lines that have a *, how do I find lines that will not?
How do I loop on the output one line at a time, without redirecting it to a file?
# 7  
Old 10-18-2010
look at "-v" option of grep
Login or Register to Ask a Question

Previous Thread | Next Thread

9 More Discussions You Might Find Interesting

1. UNIX for Beginners Questions & Answers

Reading a file line by line and print required lines based on pattern

Hi All, i want to write a shell script read below file line by line and want to exclude the lines which contains empty value for MOUNTPOINT field. i am using centos 7 Operating system. want to read below file. # cat /tmp/d5 NAME="/dev/sda" TYPE="disk" SIZE="60G" OWNER="root"... (4 Replies)
Discussion started by: balu1234
4 Replies

2. Shell Programming and Scripting

Reading line by line from live log file using while loop and considering only those lines start from

Hi, I want to read a live log file line by line and considering those line which start from time stamp; Below code I am using, which read line but throws an exception when comparing line that does not contain error code tail -F /logs/COMMON-ERROR.log | while read myline; do... (2 Replies)
Discussion started by: ketanraut
2 Replies

3. Shell Programming and Scripting

Comparison of fields then increment a counter reading line by line in a file

Hi, i have a scenario were i should compare a few fields from each line then increment a variable based on that. Example file 989878|8999|Y|0|Y|N|V 989878|8999|Y|0|N|N|V 989878|8999|Y|2344|Y|N|V i have 3 conditions to check and increment a variable on every line condition 1 if ( $3... (4 Replies)
Discussion started by: selvankj
4 Replies

4. Shell Programming and Scripting

Reading text file, comparing a value in a line, and placing only part of the line in a variable?

I need some help. I would like to read in a text file. Take a variable such as ROW-D-01, compare it to what's in one line in the text file such as PROD/VM/ROW-D-01 and only input PROD/VM into a variable without the /ROW-D-01. Is this possible? any help is appreciated. (2 Replies)
Discussion started by: xChristopher
2 Replies

5. Shell Programming and Scripting

How to start reading from the nth line till the last line of a file.

Hi, For my reuirement, I have to read a file from the 2nd line till the last line<EOF>. Say, I have a file as test.txt, which as a header record in the first line followed by records in rest of the lines. for i in `cat test.txt` { echo $i } While doing the above loop, I have read... (5 Replies)
Discussion started by: machomaddy
5 Replies

6. UNIX for Dummies Questions & Answers

Parsing file, reading each line to variable, evaluating date/time stamp of each line

So, the beginning of my script will cat & grep a file with the output directed to a new file. The data I have in this file needs to be parsed, read and evaluated. Basically, I need to identify the latest date/time stamp and then calculate whether or not it is within 15 minutes of the current... (1 Reply)
Discussion started by: hynesward
1 Replies

7. Shell Programming and Scripting

[Solved] Problem in reading a file line by line till it reaches a white line

So, I want to read line-by-line a text file with unknown number of files.... So: a=1 b=1 while ; do b=`sed -n '$ap' test` a=`expr $a + 1` $here do something with b etc done the problem is that sed does not seem to recognise the $a, even when trying sed -n ' $a p' So, I cannot read... (3 Replies)
Discussion started by: hakermania
3 Replies

8. Shell Programming and Scripting

reading a file inside awk and processing line by line

Hi Sorry to multipost. I am opening the new thread because the earlier threads head was misleading to my current doubt. and i am stuck. list=`cat /u/Test/programs`; psg "ServTest" | awk -v listawk=$list '{ cmd_name=($5 ~ /^/)? $9:$8 for(pgmname in listawk) ... (6 Replies)
Discussion started by: Anteus
6 Replies

9. Shell Programming and Scripting

Reading a file line by line and processing for each line

Hi, I am a beginner in shell scripting. I have written the following script, which is supposed to process the while loop for each line in the sid_home.txt file. But I'm getting the 'end of file' unexpected for the last line. The file sid_home.txt gets generated as expected, but the script... (6 Replies)
Discussion started by: sagarparadkar
6 Replies
Login or Register to Ask a Question