
- Kali Linux Tutorial
- Kali Linux - Home
- Installation & Configuration
- Information Gathering Tools
- Vulnerability Analyses Tools
- Kali Linux - Wireless Attacks
- Website Penetration Testing
- Kali Linux - Exploitation Tools
- Kali Linux - Forensics Tools
- Kali Linux - Social Engineering
- Kali Linux - Stressing Tools
- Kali Linux - Sniffing & Spoofing
- Kali Linux - Password Cracking Tools
- Kali Linux - Maintaining Access
- Kali Linux - Reverse Engineering
- Kali Linux - Reporting Tools
- Kali Linux Useful Resources
- Kali Linux - Quick Guide
- Kali Linux - Useful Resources
- Kali Linux - Discussion
How to limit the number of results returned from grep in Linux?
In order to be able to grep limit the number of results returned from grep command in Linux, we must first understand what a grep command is and how to use it on Linux.
The grep command in Linux is used to filter searches in a file for a particular pattern of characters. It is one of the most used Linux utility commands to display the lines that contain the pattern that we are trying to search.
Normally, the pattern that we are trying to search in the file is referred to as the regular expression.
Syntax
grep [options] pattern [files]
While there are plenty of different options available to us, some of the most used are −
-c : It lists only a count of the lines that match a pattern -h : displays the matched lines only. -i : Ignores, case for matching -l : prints filenames only -n : Display the matched lines and their line numbers. -v : It prints out all the lines that do not match the pattern
Syntax
grep -rni "word" *
In the above command replace the “word” placeholder with
For that we make use of the command shown below −
grep -rni "func main()" *
The above command will try to find a string “func main()” in all the files in a particular directory and also in the subdirectories as well.
Output
main.go:120:func main() {}
In case we only want to find a particular pattern in a single directory and not the subdirectories then we need to use the command shown below −
grep -s "func main()" *
In the above command we made use of the -s flag which will help us to not get a warning for each subdirectory that is present inside the directory where we are running the command.
Output
main.go:120:func main() {}
Now, consider that I have a .txt file and the content of the file looks something like this.
Command
immukul@192 d2 % cat 2.txt orange apple is great together apple not great is apple good orange good apple not
Now I want to use the grep command for all the lines that contain both the words ‘apple’ and ‘orange’.
Command
grep 'orange' 2.txt | grep 'apple'
Output
immukul@192 d2 % grep 'orange' 2.txt | grep 'apple' orange apple is great together orange good apple not
Now that we can notice that two strings matched with our grep query, we can limit the result with the help of the command shown below
Command
grep -m 1 'orange' 2.txt | grep 'apple
Output
immukul@192 d2 % grep -m 1 'orange' 2.txt | grep 'apple' orange apple is great together
- Related Articles
- Exclude grep From ps Results on Linux
- How to suppress a binary file matching results in grep on Linux?
- How to limit the amount of characters returned from a field in a MongoDB?
- How to limit the amount of characters returned from a field in a MongoDB query?
- How to preserve colouring after piping grep to grep in Linux?
- Limit total number of results across tables in MySQL?
- How to grep multiline search patterns in Linux?
- How to grep string without filenames in Linux?
- How to invert a grep expression on Linux?
- How to limit records to only the last five results in MySQL
- How to limit network bandwidth on linux
- How to grep and replace a word in a file on Linux?
- Limit length of longtext field in MySQL SELECT results?
- Which rows are returned while using LIMIT with OFFSET in MySQL?
- How to grep a string in a directory and all its subdirectories in Linux?
