Only matching each different pattern once


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Only matching each different pattern once
# 1  
Old 11-29-2008
Only matching each different pattern once

I have the following snippet of script:

Code:
for i in `ps axuc | awk '{ print $11 }' | grep -c 1 awk '{ print $1 }'` ; do
        ps axuc | grep $i | awk '{ do { x+=1 ; y+=$4 } while ( x < NR )} END { print y }'
done

The idea is to:

a) print the process list
b) grab the last field ($11 == command name)
c) execute addition for CPU utilization ($4 = %cpu key of ps) for each command name separately
d) print the result of addition

However, as there are many processes started with the same name (eg. httpd), it performs the addition redundantly for each instance. I presume the solution would be to modify the for-loop's preceding statement (assigning the field 11 of the output of ps to $i) to exclude the repeated occurences from being assigned to $i.

I guess the problem is rather simple, but I can't figure it out.

I tried the following:

Code:
for i in `ps axuc | awk '{ print $11 }' | grep -c 1 `ps axuc | awk '{ print $11 }'`` ; do [...]

First of all, of course; that is ridiculous. Second, it doesn't work:

syntax error: `|' unexpected

Anyone have any tips??
# 2  
Old 11-29-2008
Bug

The solution lied commands "sort" and "uniq":

$ for i in `ps axuc | sed '1d' | awk '{ print $11 }' | sort | uniq` ; do sum=$(ps axuc | grep $i | awk '{ do { x+=1 ; y+=$4 } while ( x < NR )} END { print y }') ; print "$i\t" "$sum" ; done
cron 0.1
getty 0
httpd 3.3
inetd 0
init 0
irssi 0.4
ksh 0.4
mech 0.2
mountd 0
nano 0.6
nfsd 0
nmbd 0.2
ntpd 0.2
portmap 0.1
ps 0.1
screen 1
sftp-server 0.5
smbd 0
ssh 3
sshd 2.4
syslogd 0.2

# 3  
Old 11-29-2008
Are you looking for something like this?

Code:
ps aux|awk 'NR>1{a[$11]+=$4}END{for(i in a)print i,a[i]}'

# 4  
Old 11-29-2008
Yes!

Thanks for the reply, your code is much cleaner & robust than what I came up with as a solution. Nice and compact.

Also, I didn't realize awk had arrays.

Thanks again!
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Big pattern file matching within another pattern file in awk or shell

Hi I need to do a patten match between files . I am new to shell scripting and have come up with this so far. It take 50 seconds to process files of 2mb size . I need to tune this code as file size will be around 50mb and need to save time. Main issue is that I need to search the pattern from... (2 Replies)
Discussion started by: nitin_daharwal
2 Replies

2. UNIX for Dummies Questions & Answers

Grep -v lines starting with pattern 1 and not matching pattern 2

Hi all! Thanks for taking the time to view this! I want to grep out all lines of a file that starts with pattern 1 but also does not match with the second pattern. Example: Drink a soda Eat a banana Eat multiple bananas Drink an apple juice Eat an apple Eat multiple apples I... (8 Replies)
Discussion started by: demmel
8 Replies

3. Shell Programming and Scripting

PHP - Regex for matching string containing pattern but without pattern itself

The sample file: dept1: user1,user2,user3 dept2: user4,user5,user6 dept3: user7,user8,user9 I want to match by '/^dept2.*/' but don't want to have substring 'dept2:' in output. How to compose such regex? (8 Replies)
Discussion started by: urello
8 Replies

4. Shell Programming and Scripting

Sed: printing lines AFTER pattern matching EXCLUDING the line containing the pattern

'Hi I'm using the following code to extract the lines(and redirect them to a txt file) after the pattern match. But the output is inclusive of the line with pattern match. Which option is to be used to exclude the line containing the pattern? sed -n '/Conn.*User/,$p' > consumers.txt (11 Replies)
Discussion started by: essem
11 Replies

5. UNIX for Dummies Questions & Answers

Find pattern suffix matching pattern

Hi, I am trying to get a result out of this but fails please help. Have two files /tmp/1 & /tmp/hosts. /tmp/1 IP=123.456.789.01 WAS_HOSTNAME=abcdefgh.was.tb.dsdc /tmp/hosts 123.456.789.01 I want this result in /tmp/hosts if hostname is already there dont want duplicate entry. ... (5 Replies)
Discussion started by: rajeshwebspere
5 Replies

6. Shell Programming and Scripting

sed - matching pattern one but not pattern two

All, I have the following file: -------------------------------------- # # /etc/pam.d/common-password - password-related modules common to all services # # This file is included from other service-specific PAM config files, # and should contain a list of modules that define the services... (2 Replies)
Discussion started by: RobertBerrie
2 Replies

7. Shell Programming and Scripting

counting the lines matching a pattern, in between two pattern, and generate a tab

Hi all, I'm looking for some help. I have a file (very long) that is organized like below: >Cluster 0 0 283nt, >01_FRYJ6ZM12HMXZS... at +/99% 1 279nt, >01_FRYJ6ZM12HN12A... at +/99% 2 281nt, >01_FRYJ6ZM12HM4TS... at +/99% 3 283nt, >01_FRYJ6ZM12HM946... at +/99% 4 279nt,... (4 Replies)
Discussion started by: d.chauliac
4 Replies

8. Shell Programming and Scripting

Pattern Matching

Hi Folks, I have the following requirement: I have a file that is containing numerous queries. The tables name mentioned in the queries are in the following format : SchemaName.Tablename. e.g COPDB.TableName. I need to take out all the COPDB.TableName pattern and write it to a different... (6 Replies)
Discussion started by: Siv_Pat
6 Replies

9. UNIX for Dummies Questions & Answers

Pattern Matching

Hi Folks, I have the following requirement: I have a file that is containing numerous queries. The tables name mentioned in the queries are in the following format : SchemaName.Tablename. e.g COPDB.TableName. I need to take out all the COPDB.TableName pattern and write it to a different... (0 Replies)
Discussion started by: Siv_Pat
0 Replies

10. Shell Programming and Scripting

comment/delete a particular pattern starting from second line of the matching pattern

Hi, I have file 1.txt with following entries as shown: 0152364|134444|10.20.30.40|015236433 0233654|122555|10.20.30.50|023365433 ** ** ** In file 2.txt I have the following entries as shown: 0152364|134444|10.20.30.40|015236433 0233654|122555|10.20.30.50|023365433... (4 Replies)
Discussion started by: imas
4 Replies
Login or Register to Ask a Question