Operator.itemgetterは、単独で使用()関数
- この機能を使用すると、オペレータのパッケージを呼び出す必要があります。
- 次元どのデータ、パラメータは、オブジェクトIDの数は、この機能を得るために使用されます。
例1:
a = np.random.randint(0, 100, (5, 1, 5))
b = operator.itemgetter(1) # 定义函数b,获取对象的第1个域的值
print(a)
print(b(a))
結果は以下のとおりです。
[[[ 3 58 52 99 49]]
[[ 8 79 42 66 16]]
[[34 16 39 82 72]]
[[ 7 25 97 12 67]]
[[78 52 84 33 63]]]
[[ 8 79 42 66 16]]
例二:
a = np.random.randint(0, 100, (5, 1, 5))
b = operator.itemgetter(1, 2)
print(a)
print(b(a))
[[[65 24 92 13 16]]
[[33 63 17 13 66]]
[[99 85 30 89 79]]
[[20 98 33 92 49]]
[[18 2 86 40 27]]]
(array([[33, 63, 17, 13, 66]]), array([[99, 85, 30, 89, 79]]))
()関数は、ソートで使用されています
例1:
a = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
print(a)
c = sorted(a, key=operator.itemgetter(2))
print(c)
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
この例では、3桁目に従ってソートすることを実証します。
例2:
a = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
print(a)
c = sorted(a, key=operator.itemgetter(1, 2))
print(c)
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
[('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]
この例では、第二の文字に係ることを実証し、次に3桁目に従ってソート。