operator.itemgetter()関数の使用法

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桁目に従ってソート。

公開された42元の記事 ウォンの賞賛1 ビュー753

おすすめ

転載: blog.csdn.net/qq_36758914/article/details/104043732