Python - получить локальный IP-адрес

Возможный дубликат:
Поиск локальных IP-адресов с использованием stdlib Python

Чтобы получить мой IP-адрес localhost, я делаю socket.gethostbyname(socket.gethostname()). Но это дает мне ответ 127.0.0.1. Если я делаю an_existing_socket.getsockname()[0], я получаю ответ 0.0.0.0.

Мне нужен мой "реальный" ip-адрес (например, 192.168.x.x) для изменения файла конфигурации. Как я мог его получить?

Ответ 1

Обычно я использую этот код:

import os
import socket

if os.name != "nt":
    import fcntl
    import struct

    def get_interface_ip(ifname):
        s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        return socket.inet_ntoa(fcntl.ioctl(s.fileno(), 0x8915, struct.pack('256s',
                                ifname[:15]))[20:24])

def get_lan_ip():
    ip = socket.gethostbyname(socket.gethostname())
    if ip.startswith("127.") and os.name != "nt":
        interfaces = [
            "eth0",
            "eth1",
            "eth2",
            "wlan0",
            "wlan1",
            "wifi0",
            "ath0",
            "ath1",
            "ppp0",
            ]
        for ifname in interfaces:
            try:
                ip = get_interface_ip(ifname)
                break
            except IOError:
                pass
    return ip

Я не знаю его происхождения, но он работает на Linux/Windows.

Edit:

Этот код используется smerlin в this stackoverflow.

Ответ 2

Существует отличный модуль, который вы можете использовать. Его называли нетипахи. Просто попробуйте установить netifaces в virtualenv для тестирования и попробуйте следующий код:

import netifaces

interfaces = netifaces.interfaces()
for i in interfaces:
    if i == 'lo':
        continue
    iface = netifaces.ifaddresses(i).get(netifaces.AF_INET)
    if iface != None:
        for j in iface:
            print j['addr']

Все зависит от вашей среды. Если у вас есть только один интерфейс с одним подключенным к нему IP-адресом, вы можете просто сделать:

netifaces.ifaddresses('eth0')[netifaces.AF_INET][0]['addr']

Если вы находитесь за NAT и хотите узнать свой публичный IP-адрес, вы можете использовать что-то вроде:

import urllib2

ret = urllib2.urlopen('https://enabledns.com/ip')
print ret.read()

Надеюсь, что это поможет.