खोज…


वाक्य - विन्यास

  • खाली_सेट = सेट () # एक खाली सेट इनिशियलाइज़ करें
  • शाब्दिक_सेट = {'फू', 'बार', 'बाज'} # इसके अंदर 3 तार के साथ एक सेट का निर्माण
  • set_from_list = set (['foo', 'bar', 'baz']] # नए सेट के लिए सेट फ़ंक्शन को कॉल करें
  • set_from_iter = set (x के लिए x सीमा में (30)) # सेट बनाने के लिए मनमाने पुनरावृत्तियों का उपयोग करें
  • set_from_iter = {x in x के लिए [random.randint (0,10) के लिए मैं सीमा में (10)]} # वैकल्पिक संकेतन

टिप्पणियों

यदि आप तकनीकी प्राप्त करना चाहते हैं तो सेट अनियंत्रित हैं और बहुत तेज़ी से देखने का समय (amortized O (1) है)। जब आपके पास चीजों का संग्रह होता है, तो इसका उपयोग करना बहुत अच्छा होता है, ऑर्डर मायने नहीं रखता है, और आप बहुत नाम से आइटम देख रहे होंगे। यदि यह एक इंडेक्स नंबर द्वारा आइटम देखने के लिए अधिक समझ में आता है, तो इसके बजाय एक सूची का उपयोग करने पर विचार करें। यदि आदेश मायने रखता है, तो एक सूची पर भी विचार करें।

सेट परिवर्तनशील होते हैं और इस तरह से हैशेड नहीं किया जा सकता है, इसलिए आप उन्हें शब्दकोश कुंजियों के रूप में उपयोग नहीं कर सकते हैं या उन्हें अन्य सेटों में, या कहीं और धोने योग्य प्रकारों की आवश्यकता नहीं है। ऐसे मामलों में, आप एक अपरिवर्तनीय frozenset उपयोग कर सकते हैं।

एक सेट के तत्व धोने योग्य होने चाहिए। इसका मतलब है कि उनके पास एक सही __hash__ विधि है, जो __eq__ अनुरूप है। सामान्य तौर पर, उत्परिवर्तनीय प्रकार जैसे कि list या set को धोने योग्य नहीं set जाता है और इसे set में नहीं रखा जा सकता है। यदि आप इस समस्या का सामना करते हैं, तो dict और अपरिवर्तनीय कुंजियों का उपयोग करने पर विचार करें।

किसी सूची के अनन्य तत्व प्राप्त करें

मान लीजिए कि आपको रेस्तरां की एक सूची मिल गई है - शायद आप इसे एक फ़ाइल से पढ़ते हैं। आप सूची में अद्वितीय रेस्तरां की परवाह करते हैं। एक सूची से अद्वितीय तत्वों को प्राप्त करने का सबसे अच्छा तरीका है कि इसे एक सेट में बदल दिया जाए:

restaurants = ["McDonald's", "Burger King", "McDonald's", "Chicken Chicken"]
unique_restaurants = set(restaurants)
print(unique_restaurants)
# prints {'Chicken Chicken', "McDonald's", 'Burger King'}

ध्यान दें कि सेट मूल सूची के समान क्रम में नहीं है; ऐसा इसलिए है क्योंकि सेट अनियंत्रित होते हैं, जैसे कि dict

यह आसानी से एक में वापस तब्दील किया जा सकता List अजगर में निर्मित के साथ list एक और सूची है कि मूल रूप में, लेकिन डुप्लिकेट के बिना एक ही सूची है दे रही है समारोह,:

list(unique_restaurants)
# ['Chicken Chicken', "McDonald's", 'Burger King']

इसे एक पंक्ति के रूप में देखना भी आम है:

# Removes all duplicates and returns another list
list(set(restaurants))

अब कोई भी ऑपरेशन जो मूल सूची पर किया जा सकता था, उसे फिर से किया जा सकता है।

सेट पर संचालन

अन्य सेटों के साथ

# Intersection    
{1, 2, 3, 4, 5}.intersection({3, 4, 5, 6})  # {3, 4, 5}
{1, 2, 3, 4, 5} & {3, 4, 5, 6}              # {3, 4, 5}

# Union
{1, 2, 3, 4, 5}.union({3, 4, 5, 6})  # {1, 2, 3, 4, 5, 6}
{1, 2, 3, 4, 5} | {3, 4, 5, 6}       # {1, 2, 3, 4, 5, 6}

# Difference
{1, 2, 3, 4}.difference({2, 3, 5})  # {1, 4}
{1, 2, 3, 4} - {2, 3, 5}            # {1, 4}

# Symmetric difference with
{1, 2, 3, 4}.symmetric_difference({2, 3, 5})  # {1, 4, 5}
{1, 2, 3, 4} ^ {2, 3, 5}                      # {1, 4, 5}

# Superset check
{1, 2}.issuperset({1, 2, 3})  # False
{1, 2} >= {1, 2, 3}           # False

# Subset check
{1, 2}.issubset({1, 2, 3})  # True
{1, 2} <= {1, 2, 3}         # True

# Disjoint check
{1, 2}.isdisjoint({3, 4})  # True
{1, 2}.isdisjoint({1, 4})  # False

एकल तत्वों के साथ

# Existence check
2 in {1,2,3}      # True
4 in {1,2,3}      # False
4 not in {1,2,3}  # True

# Add and Remove
s = {1,2,3}
s.add(4)        # s == {1,2,3,4}

s.discard(3)    # s == {1,2,4}
s.discard(5)    # s == {1,2,4}

s.remove(2)     # s == {1,4}
s.remove(2)     # KeyError!

सेट ऑपरेशंस नए सेट लौटाते हैं, लेकिन इसके स्थान पर संस्करण होते हैं:

तरीका इन-प्लेस ऑपरेशन इन-प्लेस विधि
संघ s। = t अपडेट करें
चौराहा s & = t intersection_update
अंतर s - = t difference_update
symmetric_difference s ^ = t symmetric_difference_update

उदाहरण के लिए:

s = {1, 2}
s.update({3, 4})   # s == {1, 2, 3, 4}

मल्टीसेट्स बनाम सेट

सेट अलग-अलग तत्वों के अनियोजित संग्रह हैं। लेकिन कभी-कभी हम उन तत्वों के अनियंत्रित संग्रह के साथ काम करना चाहते हैं जो जरूरी नहीं कि अलग-अलग हों और तत्वों के गुणन पर नज़र रखें।

इस उदाहरण पर विचार करें:

>>> setA = {'a','b','b','c'}
>>> setA
set(['a', 'c', 'b'])

स्ट्रिंग्स 'a' , 'b' , 'b' , 'c' को एक सेट डेटा संरचना में सहेज कर हमने इस तथ्य की जानकारी खो दी है कि 'b' दो बार होता है। बेशक तत्वों को किसी सूची में सहेजना इस जानकारी को बनाए रखेगा

>>> listA = ['a','b','b','c']
>>> listA
['a', 'b', 'b', 'c']

लेकिन एक सूची डेटा संरचना एक अतिरिक्त अनावश्यक आदेश का परिचय देती है जो हमारी गणना को धीमा कर देती है।

मल्टीसेट्स लागू करने के लिए पायथन collections मॉड्यूल से Counter क्लास प्रदान करता है (संस्करण 2.7 से शुरू):

पायथन 2.x 2.7
>>> from collections import Counter
>>> counterA = Counter(['a','b','b','c'])
>>> counterA
Counter({'b': 2, 'a': 1, 'c': 1})

Counter एक ऐसा शब्दकोश है जहाँ तत्वों को शब्दकोश कुंजियों के रूप में संग्रहीत किया जाता है और उनकी गणना को शब्दकोश मान के रूप में संग्रहीत किया जाता है। और सभी शब्दकोशों के रूप में, यह एक अनियोजित संग्रह है।

मेथड्स और बिलिंस का उपयोग करके संचालन सेट करें

हम दो सेटों को परिभाषित करते हैं a और b

>>> a = {1, 2, 2, 3, 4}
>>> b = {3, 3, 4, 4, 5}

नोट: {1} एक तत्व का एक सेट बनाता है, लेकिन {} एक खाली dict बनाता है। खाली सेट बनाने का सही तरीका set()

चौराहा

a.intersection(b) a और b दोनों में मौजूद तत्वों के साथ एक नया सेट लौटाता है

>>> a.intersection(b)
{3, 4}

संघ

a.union(b) a और b दोनों में मौजूद तत्वों के साथ एक नया सेट लौटाता है

>>> a.union(b)
{1, 2, 3, 4, 5}

अंतर

a.difference(b) में मौजूद तत्वों के साथ एक नया सेट देता है a लेकिन में नहीं b

>>> a.difference(b)
{1, 2}
>>> b.difference(a)
{5}

सममित अंतर

a.symmetric_difference(b) या तो में तत्वों वर्तमान के साथ एक नया सेट देता है a या b लेकिन दोनों में नहीं

>>> a.symmetric_difference(b)
{1, 2, 5}
>>> b.symmetric_difference(a)
{1, 2, 5}

नोट : a.symmetric_difference(b) == b.symmetric_difference(a)

सबसेट और सुपरसेट

c.issubset(a) कि c का प्रत्येक तत्व a में है a

a.issuperset(c) परीक्षण करता है कि c का प्रत्येक तत्व a में है a

>>> c = {1, 2}
>>> c.issubset(a)
True
>>> a.issuperset(c)
True

बाद के संचालन के बराबर ऑपरेटर हैं जैसा कि नीचे दिखाया गया है:

तरीका ऑपरेटर
a.intersection(b) a & b
a.union(b) a | b
a.difference(b) a - b
a.symmetric_difference(b) a ^ b
a.issubset(b) a <= b
a.issuperset(b) a >= b

विघटन सेट

यदि कोई तत्व d और इसके विपरीत में भी है, तो a और d a से भिन्न हैं।

>>> d = {5, 6}
>>> a.isdisjoint(b) # {2, 3, 4} are in both sets
False
>>> a.isdisjoint(d)
True

# This is an equivalent check, but less efficient
>>> len(a & d) == 0
True

# This is even less efficient
>>> a & d == set()
True

परीक्षण सदस्यता

बिल्ट in कीवर्ड खोजता है

>>> 1 in a
True
>>> 6 in a
False

लंबाई

बिलिन len() फ़ंक्शन सेट में तत्वों की संख्या लौटाता है

>>> len(a)
4
>>> len(b)
3

सेट का सेट

{{1,2}, {3,4}}

फलस्वरूप होता है:

TypeError: unhashable type: 'set'

इसके बजाय, frozenset उपयोग frozenset :

{frozenset({1, 2}), frozenset({3, 4})}


Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow