我遇到的问题是我基本上想找到BGP聚合地址(例如:10.76.32.0 255.255.240.0)与同一路由器上的所有网络命令之间是否有任何免费子网(例如:10.76) .32.0 255.255.255.0,10.76.33.0 255.255.255.0)
在上面的例子10.76.34.0中 - > 10.76.47.255将是免费的。
我正在考虑通过将IP地址和子网掩码转换为二进制并减去该方式来解决此问题。
为了保持简单,我将这个例子保留为十进制,但这样做会让我遇到以下问题:假设我的范围从1到250,我从这减去20到23的较小范围,我希望最终的范围从1到19和24到250。
使用range命令并没有真正给我预期的结果,虽然我可能会创建一个包含该范围内每个项目的列表,并使用一组子项减去另一个列表,但在我看来它可能不会拥有可能有数万个元素的列表是一个好主意。
Hunor
答案 0 :(得分:1)
如果您尝试创建一个带有间隙的“范围”,即1-9和24-250,您可以尝试使用filterfalse
(或ifilterfalse
如果您是使用来自itertools
模块的Python 2.X),该模块将谓词和序列作为其参数,并返回谓词返回False
的序列元素。例如,如果你这样做:
from itertools import filterfalse
new_range = filterfalse(lambda x: 20 <= x <= 23, range(1,251))
new_range
将是一个包含数字1-19和24-250的迭代,可以与range()
类似地使用:
for i in new_range:
do_things()
答案 1 :(得分:0)
这个问题已经很久以前问过了,但是我想添加numpy array
答案。
import numpy as np
aa=np.arange(1,251)
bb=np.concatenate((np.array(aa[aa<20]),np.array(aa[aa>23])))
print(bb)
输出
array([ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,
14, 15, 16, 17, 18, 19, 24, 25, 26, 27, 28, 29, 30,
31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43,
44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56,
57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69,
70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82,
83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95,
96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108,
109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121,
122, 123, 124, 125, 126, 127, 128, 129, 130, 131, 132, 133, 134,
135, 136, 137, 138, 139, 140, 141, 142, 143, 144, 145, 146, 147,
148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, 160,
161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173,
174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186,
187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199,
200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212,
213, 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225,
226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238,
239, 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250])