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

Jakiego wyrażenia regularnego mogę użyć, aby dopasować adres IP?

Za pomocą następującej składni grep chcę dopasować wszystkie adresy IP w pliku (ze skryptu ksh)

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

Problem: Dopasowuje również słowa (IP), które mają więcej niż 4 oktety:

1.1.1.1.1

lub

192.1.1.1.160

Jak mogę dopasować ważne IP i tylko adresy IP z 4 oktetami? Mogę też użyć Perla - jednolinijkowe rozwiązanie, jeśli grep nie zadziała.

Odpowiedzi (12)

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

spróbuj tego:

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

co pasuje do wszystkich wyrażeń od 0.0.0.0 do 999.999.999.999

z

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

otrzymasz adresy IP tylko

uwaga: na solarisie prawdopodobnie egrep załatwi sprawę.

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

Jak to jest:

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

Aby znaleźć tylko dopasowania z dokładnie 4 oktetami (wyłączając rzeczy takie jak 1.1.1.1.1) użyj tego:

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

To nigdy nie powinno wykryć adresów innych niż IP. Wyrażenie może być bardziej złożone, aby sprawdzić więcej rzeczy, ale to powinno działać w większości przypadków. Nie będzie pasować do poprzedzającego 0, ponieważ 010.1.12.1 nie jest powszechnym sposobem zapisu adresów IP.

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

Flaga

-w / --word-regexp

do grep sprawia, że dopasowuje tylko granice słów, co oznacza, że twoje dopasowanie musi być albo otoczone białą spacją, albo zaczynać się / kończyć na początku / końcu linii!

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

Trochę skomplikowane, ale powinno zadziałać:

( 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

Krótsza wersja długiego regex:

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

Proszę użyć grep -E lub egrep odpowiednio do wersji systemu operacyjnego.

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

Wyrażenie regularne dla dopasowania adresu ip w 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}’

Przykład : 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])$’

Zmodyfikowana wersja odpowiedzi Arnaud B.

To wyrażenie nie będzie pasowało do adresów IP z początkowymi 0. np., nie będzie pasowało do 192.168.1.01 To wyrażenie nie będzie pasowało do adresów IP z więcej niż 4 oktetami. np., nie będzie pasowało do 192.168.1.2.3

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

Używam egrep "^([0-9]{1,3}\.){3}[0-9]{1,3}" /etc/hosts do dopasowania adresów IP na początku linii. Może być również użyty bez ^, aby pozwolić na białe spacje lub inne znaki przed adresem IP.

[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

Oto co działało dla mnie dla ksh i ksh93 w 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 Powyższe można zmodyfikować tak, aby “odfiltrować” podane IP według dowolnego wzoru.