PyQtクラスを使用してこれまでに行ったこと:
all_Addresses = QNetworkInterface.allAddresses() #list-of-QHostAddress
for addr in all_Addresses:
print(addr.toString())
出力:
172.16.0.186 - Virtual Interface IP address
192.168.10.2 - Physical interface IP address. I want this one.
127.0.0.1
socket
の使用:
import socket
print(socket.gethostbyname(socket.gethostname()))
出力:
172.16.0.186 - When openVPN is on
192.168.10.2 - When its off
netifaces を使用する必要があります。これはクロスプラットフォームになるように設計されており、さまざまなUNIX/UNIXのようなプラットフォームで動作するさまざまな汎用バージョンとともに、Windows用の特殊なコードが含まれています。
netifaces バージョン0.10.0以降、Python3がサポートされています。
>>> from netifaces import AF_INET, AF_INET6, AF_LINK, AF_PACKET, AF_BRIDGE
>>> import netifaces as ni
>>> ni.interfaces()
['lo', 'eth0', 'eth1', 'vboxnet0', 'dummy1']
>>>
>>> ni.ifaddresses('eth0')[AF_LINK] # NOTE: AF_LINK is an alias for AF_PACKET
[{'broadcast': 'ff:ff:ff:ff:ff:ff', 'addr': '00:02:55:7b:b2:f6'}]
>>> ni.ifaddresses('eth0')[AF_INET]
[{'broadcast': '172.16.161.7', 'netmask': '255.255.255.248', 'addr': '172.16.161.6'}]
>>>
>>> # eth0 ipv4 interface address
>>> ni.ifaddresses('eth0')[AF_INET][0]['addr']
'172.16.161.6'
>>>>
ほとんどのMS Windowsインストールにコンパイラは必要ありません。 MS Visual C++ for Windowsのインストールに関する警告が表示された場合は、pythonで使用するコンパイラのバージョンとモジュールで使用するコンパイラのバージョンを一致させる必要があるため、 非常に注意 にしてください。
>>> import netifaces as ni
>>> ni.interfaces()
['lo', 'eth0', 'eth1', 'vboxnet0', 'dummy1']
>>> ni.ifaddresses('eth0')
{
17: [
{
'broadcast': 'ff:ff:ff:ff:ff:ff',
'addr': '00:02:55:7b:b2:f6'
}
],
2: [
{
'broadcast': '172.16.161.7',
'netmask': '255.255.255.248',
'addr': '172.16.161.6'
}
],
10: [
{
'netmask': 'ffff:ffff:ffff:ffff::',
'addr': 'fe80::202:55ff:fe7b:b2f6%eth0'
}
]
}
>>>
>>> print(ni.ifaddresses.__doc__)
Obtain information about the specified network interface.
Returns a dict whose keys are equal to the address family constants,
e.g. netifaces.AF_INET, and whose values are a list of addresses in
that family that are attached to the network interface.
>>>
>>> # for the IPv4 address of eth0
>>> ni.ifaddresses('eth0')[2][0]['addr']
'172.16.161.6'
プロトコルのインデックス付けに使用される番号は/usr/include/linux/socket.h
(Linuxの場合)...[〜#〜] edit [〜#〜]からのものです。私の3.2カーネルはここにそれらを持っています:/usr/src/linux-headers-3.2.0-4-common/include/linux/socket.h
#define AF_INET 2 /* Internet IP Protocol */
#define AF_INET6 10 /* IP version 6 */
#define AF_PACKET 17 /* Packet family */
良いニュースは、これらのヘッダー定数をすべて覚えておく必要がないことです。これらは netifaces に含まれています。
>>> from netifaces import AF_INET, AF_INET6, AF_LINK, AF_PACKET, AF_BRIDGE
>>> import netifaces as ni
Linux SIOCGIFADDR ioctlを使用して、ネットワークインターフェースに関連付けられているIPアドレスを見つけます。 「eth0
"。アドレスは、ドット付きクワッドを含む文字列として返されます。
import socket
import fcntl
import struct
def get_ip_address(ifname):
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
return socket.inet_ntoa(fcntl.ioctl(
s.fileno(),
0x8915, # SIOCGIFADDR
struct.pack('256s', ifname[:15])
)[20:24])
>>> get_ip_address('lo')
'127.0.0.1'
>>> get_ip_address('eth0')
'38.113.228.130'
このソリューションを使用します。実際には少しトリッキーで、Linuxファミリでのみ機能します。
import commands
intf = 'eth0'
intf_ip = commands.getoutput("ip address show dev " + intf).split()
intf_ip = intf_ip[intf_ip.index('inet') + 1].split('/')[0]
print intf_ip
これらのコードは、Linuxファミリオペレーティングシステムでip
コマンドを利用します。 ip
コマンドからの出力を分割し、それらのインターフェースのIPv4アドレスのみを取得します。値intf
をeth1
またはp2p1
に変更できます。