2010-10-24 12:00:49 +0000 2010-10-24 12:00:49 +0000
36
36

Welke reguliere expressie kan ik gebruiken om een IP-adres te matchen?

Met de volgende grep syntaxis wil ik alle IP adressen in een bestand matchen (van een ksh script)

grep '[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}' file

Het probleem: Het match ook woorden (IP) die meer dan 4 octetten hebben:

1.1.1.1.1

of

192.1.1.1.160

Hoe kan ik een geldig IP matchen en alleen IP adressen met 4 octetten? Ik kan ook Perl gebruiken - een één-regel syntaxis oplossing, als grep niet werkt.

答案 (12)

57
57
57
2010-10-24 13:01:43 +0000

probeer dit eens:

grep -E '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' /etc/hosts

die overeenkomt met alle expressies van 0.0.0.0 tot 999.999.999.999

met

grep -Eo '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}' /etc/hosts

krijg je alleen IP-adressen

note: op solaris waarschijnlijk egrep zal het werk doen.

10
10
10
2010-10-24 13:50:10 +0000

Wat vind je hiervan:

perl -MRegexp::Common=net -ne '/($RE{net}{IPv4})/ and print "$1\n"' /etc/hosts
5
5
5
2012-09-13 08:12:16 +0000
if [` echo $ip | '^((25[0-5]|2[0-4][0-9]|[01]?[1-9][0-9]?)\.){3}(25[0-5]|2[0-4][0-9]|[01]?[1-9][0-9]?)$' | grep -o "\." | wc -l` -eq 1 ];
then ipv4=true;
else 
ipv4=false;
5
5
5
2012-09-13 08:35:57 +0000

Om alleen overeenkomsten te vinden met 4 octetten precies (uitgezonderd dingen als 1.1.1.1.1) gebruik je dit:

grep -P '(?<=[^0-9.]|^)[1-9][0-9]{0,2}(\.([0-9]{0,3})){3}(?=[^0-9.]|$)'

Het zou nooit niet-IP-adressen moeten detecteren. De expressie zou complexer kunnen zijn om meer dingen te verifiëren, maar dit zou in de meeste gevallen moeten werken. Het zal niet overeenkomen met een voorafgaande 0 aangezien 010.1.12.1 geen gebruikelijke manier is om IP-adressen te schrijven.

5
5
5
2012-06-26 11:15:04 +0000

De

-w / --word-regexp

vlag naar grep zorgt ervoor dat het alleen overeenkomt op woordgrenzen, wat betekent dat uw overeenkomst ofwel moet worden omgeven door witruimte of moet beginnen / eindigen aan het begin / einde van de regel!

3
3
3
2010-10-24 15:14:58 +0000

Een beetje lastig, maar het zou moeten werken:

( X='\([0-9]\{1,2\}\|1[0-9]\{2\}\|2[0-4][0-9]\|25[0-5]\)' ; grep "\([^\.]\|^\)$X\.$X\.$X\.$X\([^\.]\|$\)" file )
1
1
1
2015-11-17 09:56:08 +0000

Een kortere versie van de lange regex:

egrep '([1-2]?[0-9]{0,2}\.){3,3}[1-2]?[0-9]{0,2}'

Gebruik grep -E of egrep, afhankelijk van uw OS-versie

0
0
0
2015-04-17 11:17:29 +0000

Reguliere uitdrukking voor het matchen van een ip-adres in TCL

set a “192.168.10.25”

if {[regexp
{^(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])$} $a]} 
{
puts "yes"
}
0
0
0
2016-09-01 09:46:09 +0000

grep -Eo ‘([0-9]{1,3}.?){4}’

Voorbeeld : curl http://korben.info/ip | grep “IP visible depuis mon serveur” | grep -Eo ‘([0-9]{1,3}.?){4}’

0
0
0
2013-09-02 05:56:39 +0000

grep -E ‘^((25[0-5]|2[0-4][0-9]|[1]?[1-9][0-9]?).){3}(25[0-5]|2[0-4][0-9]|[1]?[1-9]?[0-9])$’

Gewijzigde versie van Arnaud B.‘s antwoord.

Deze uitdrukking komt niet overeen met IP-adressen met voorloop 0’s. Ze komt bijvoorbeeld niet overeen met 192.168.1.01 Deze uitdrukking komt niet overeen met IP-adressen met meer dan 4 bytes. Ze komt bijvoorbeeld niet overeen met 192.168.1.2.3

0
0
0
2015-10-29 18:58:11 +0000

Ik gebruik egrep "^([0-9]{1,3}\.){3}[0-9]{1,3}" /etc/hosts om IP-adressen aan het begin van een regel te matchen. Het kan ook zonder de ^ gebruikt worden om spaties of andere karakters voor het IP adres toe te staan.

[0-9]{1,3} --> this matches a number between 1 and 999.
\. --> this is to add the dot.
([0-9]{1,3}\.){3} --> get a number with a dot 3 times.
[0-9]{1,3} --> finally add the fourth number.
-1
-1
-1
2017-02-15 10:02:50 +0000

Hier is wat voor mij werkte voor ksh en ksh93 in AIX:

ip=

[[$ip == [0-9]@(“”|[0-9])@(“”|[0-9]).[0-9]@(“”|[0-9])@(“”|[0-9]).[0-9]@(“”|[0-9])@(“”|[0-9]). [0-9]@(“”|[0-9])@(“”|[0-9]) ]] && echo OK || echo NOK Het bovenstaande kan worden gewijzigd om het verstrekte IP te “filteren” op elk gewenst patroon.