0
我想能夠通過接口,然後通過inet地址分組ifconfig的輸出。另外請假定接口塊之間沒有空白。.NET正則表達式來解析ifconfig
eth0 Link encap:Ethernet HWaddr 52:54:00:12:34:56
inet addr:10.0.2.15 Bcast:10.0.2.255 Mask:255.255.255.0
inet6 addr: fe80::5054:ff:fe12:3456/64 Scope: Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:1382 errors:0 dropped:0 overruns:0 frame:0
TX packets:1344 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:247209 TX bytes:131216
Interrupt:9 Base address:0xc000
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope: Host
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:1400 errors:0 dropped:0 overruns:0 frame:0
TX packets:1400 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:109731 TX bytes:109731
wlan0 Link encap:Ethernet HWaddr CC:FA:00:A9:1D:7C
inet addr:10.92.70.35 Bcast:10.92.71.255 Mask:255.255.252.0
inet6 addr: 2001:4898:4070:101b:cefa:ff:fea9:1d7c/64 Scope: Global
inet6 addr: fe80::cefa:ff:fea9:1d7c/64 Scope: Link
inet6 addr: 2001:4898:4070:101b:1d4e:9b7f:f197:2e6f/64 Scope: Global
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:134563 errors:0 dropped:0 overruns:0 frame:0
TX packets:41967 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:75871586 TX bytes:9616476
將產生3組,我可以參考,並確定它們是否與eth
或wlan
開始,然後拉inet addr
了他們每個人的
的到目前爲止,我有@"inet addr:(?<IpV4Address>((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?))"
得到INET地址,但我還沒有想出如何分離接口塊。
你真的需要使用正則表達式來解析整個字符串嗎?爲什麼不混合一個簡單的(更簡單的?)string.split和一個普通的舊for循環? –
你有什麼建議我們分手?請記住,ifconfig的輸出沒有標準... –
基本上,你可以用新的行字符('\ n')分割。在所有行上循環。忽略空行。每當行以空格字符(製表符或空格)開始時,在分析器中「啓動」一個新的部分。 –