Ebben az oktatóanyagban mindent megtudhat a Python készletekről; hogyan jönnek létre, hozzáadva vagy eltávolítva belőlük az elemeket, valamint a Python halmazain végzett összes műveletet.
Videó: Beállítások Pythonban
A készlet rendezetlen tételgyűjtemény. Minden beállított elem egyedi (nincs duplikátum), és változhatatlannak kell lennie (nem változtatható meg).
Maga a halmaz azonban változtatható. Hozzáadhatunk vagy eltávolíthatunk belőle elemeket.
A halmazok matematikai halmazműveletek végrehajtására is használhatók, például egyesülés, metszéspont, szimmetrikus különbség stb.
Python készletek létrehozása
Egy készlet úgy jön létre, hogy az összes elemet (elemet) ()
vesszővel elválasztva göndör zárójelbe helyezi , vagy a beépített set()
funkciót használja.
Ez tetszőleges számú elemet tartalmazhat, és különböző típusúak lehetnek (egész szám, float, tuple, string stb.). De egy halmaznak nem lehetnek módosítható elemei, mint például listák, halmazok vagy szótárak.
# Different types of sets in Python # set of integers my_set = (1, 2, 3) print(my_set) # set of mixed datatypes my_set = (1.0, "Hello", (1, 2, 3)) print(my_set)
Kimenet
(1, 2, 3) (1,0, (1, 2, 3), „Hello”)
Próbálja ki a következő példákat is.
# set cannot have duplicates # Output: (1, 2, 3, 4) my_set = (1, 2, 3, 4, 3, 2) print(my_set) # we can make set from a list # Output: (1, 2, 3) my_set = set((1, 2, 3, 2)) print(my_set) # set cannot have mutable items # here (3, 4) is a mutable list # this will cause an error. my_set = (1, 2, (3, 4))
Kimenet
(1, 2, 3, 4) (1, 2, 3) Traceback (a legutóbbi hívás utoljára): Fájl "", 15. sor, itt: my_set = (1, 2, (3, 4)) TypeError: nem használható típus: 'lista'
Üres halmaz létrehozása kissé trükkös.
Az üres göndör zárójelekből ()
üres szótár lesz a Pythonban. Ha egy elemet nem szeretnénk készíteni, akkor set()
argumentum nélkül használjuk a függvényt.
# Distinguish set and dictionary while creating empty set # initialize a with () a = () # check data type of a print(type(a)) # initialize a with set() a = set() # check data type of a print(type(a))
Kimenet
Egy halmaz módosítása a Pythonban
A halmazok változtathatóak. Mivel azonban nem rendezettek, az indexelésnek nincs értelme.
Indexeléssel vagy szeleteléssel nem férhetünk hozzá vagy változtathatunk meg egy készlet elemét. A beállított adattípus nem támogatja azt.
A add()
módszer segítségével egyetlen elemet, a módszer segítségével pedig több elemet is felvehetünk update()
. A update()
módszer argumentumként sorokat, listákat, karakterláncokat vagy más halmazokat vehet fel. Minden esetben kerüljük az ismétléseket.
# initialize my_set my_set = (1, 3) print(my_set) # my_set(0) # if you uncomment the above line # you will get an error # TypeError: 'set' object does not support indexing # add an element # Output: (1, 2, 3) my_set.add(2) print(my_set) # add multiple elements # Output: (1, 2, 3, 4) my_set.update((2, 3, 4)) print(my_set) # add list and set # Output: (1, 2, 3, 4, 5, 6, 8) my_set.update((4, 5), (1, 6, 8)) print(my_set)
Kimenet
(1, 3) (1, 2, 3) (1, 2, 3, 4) (1, 2, 3, 4, 5, 6, 8)
Elemek eltávolítása egy készletből
Egy adott elem eltávolítható egy halmazból a metódusok discard()
és segítségével remove()
.
Az egyetlen különbség a kettő között az, hogy a discard()
függvény változatlanul hagy egy halmazt, ha az elem nincs jelen a halmazban. Másrészt a remove()
függvény hibát vet fel egy ilyen feltételben (ha az elem nincs a halmazban).
A következő példa ezt szemlélteti.
# Difference between discard() and remove() # initialize my_set my_set = (1, 3, 4, 5, 6) print(my_set) # discard an element # Output: (1, 3, 5, 6) my_set.discard(4) print(my_set) # remove an element # Output: (1, 3, 5) my_set.remove(6) print(my_set) # discard an element # not present in my_set # Output: (1, 3, 5) my_set.discard(2) print(my_set) # remove an element # not present in my_set # you will get an error. # Output: KeyError my_set.remove(2)
Kimenet
(1, 3, 4, 5, 6) (1, 3, 5, 6) (1, 3, 5) (1, 3, 5) Traceback (a legutóbbi hívás utoljára): "" fájl, 28. sor, in KeyError: 2
Hasonlóképpen eltávolíthatunk és visszaküldhetünk egy elemet a pop()
módszerrel.
Mivel a set rendezetlen adattípus, nincs mód meghatározni, hogy melyik elem kerüljön felbukkanásra. Teljesen önkényes.
A clear()
metódus segítségével az összes elemet is eltávolíthatjuk egy készletből .
# initialize my_set # Output: set of unique elements my_set = set("HelloWorld") print(my_set) # pop an element # Output: random element print(my_set.pop()) # pop another element my_set.pop() print(my_set) # clear my_set # Output: set() my_set.clear() print(my_set) print(my_set)
Kimenet
('H', 'l', 'r', 'W', 'o', 'd', 'e') H ('r', 'W', 'o', 'd', 'e' ) készlet ()
Python Set műveletek
A halmazok matematikai halmazműveletek, például egyesülés, metszéspont, különbség és szimmetrikus különbség végrehajtására használhatók. Megtehetjük ezt operátorokkal vagy módszerekkel.
Vizsgáljuk meg a következő két halmazt a következő műveletekhez.
>>> A = (1, 2, 3, 4, 5) >>> B = (4, 5, 6, 7, 8)
Set Union

Az A és B egyesítése mindkét halmaz összes elemének halmaza.
Az uniót |
operátor segítségével hajtják végre . Ugyanez megvalósítható a union()
módszerrel.
# Set union method # initialize A and B A = (1, 2, 3, 4, 5) B = (4, 5, 6, 7, 8) # use | operator # Output: (1, 2, 3, 4, 5, 6, 7, 8) print(A | B)
Kimenet
(1, 2, 3, 4, 5, 6, 7, 8)
Próbálja ki a következő példákat a Python shell-en.
# use union function >>> A.union(B) (1, 2, 3, 4, 5, 6, 7, 8) # use union function on B >>> B.union(A) (1, 2, 3, 4, 5, 6, 7, 8)
Állítsa be a Metszéspontot

A és B metszéspontja olyan elemek halmaza, amelyek mindkét halmazban közösek.
A kereszteződést az &
operátor segítségével hajtják végre . Ugyanez megvalósítható a intersection()
módszerrel.
# Intersection of sets # initialize A and B A = (1, 2, 3, 4, 5) B = (4, 5, 6, 7, 8) # use & operator # Output: (4, 5) print(A & B)
Kimenet
(4, 5)
Próbálja ki a következő példákat a Python shell-en.
# use intersection function on A >>> A.intersection(B) (4, 5) # use intersection function on B >>> B.intersection(A) (4, 5)
Állítsa be a Különbséget

A B halmaz különbsége az A halmaztól (A - B) olyan elemek halmaza, amelyek csak A-ban vannak, de B-ben nincsenek. Hasonlóképpen, B - A a B-ben található elemek halmaza, de A-ban nem.
A különbség az -
operátor segítségével történik . Ugyanez megvalósítható a difference()
módszerrel.
# Difference of two sets # initialize A and B A = (1, 2, 3, 4, 5) B = (4, 5, 6, 7, 8) # use - operator on A # Output: (1, 2, 3) print(A - B)
Kimenet
(1, 2, 3)
Próbálja ki a következő példákat a Python shell-en.
# use difference function on A >>> A.difference(B) (1, 2, 3) # use - operator on B >>> B - A (8, 6, 7) # use difference function on B >>> B.difference(A) (8, 6, 7)
Szimmetrikus különbség beállítása

Az A és B szimmetrikus különbsége az A és B elemek eleme, de nem mindkettőben (kivéve a metszéspontot).
A szimmetrikus különbséget az ^
operátor segítségével hajtják végre . Ugyanez megvalósítható a módszerrel symmetric_difference()
.
# Symmetric difference of two sets # initialize A and B A = (1, 2, 3, 4, 5) B = (4, 5, 6, 7, 8) # use operator # Output: (1, 2, 3, 6, 7, 8) print(A B)
Kimenet
(1, 2, 3, 6, 7, 8)
Próbálja ki a következő példákat a Python shell-en.
# use symmetric_difference function on A >>> A.symmetric_difference(B) (1, 2, 3, 6, 7, 8) # use symmetric_difference function on B >>> B.symmetric_difference(A) (1, 2, 3, 6, 7, 8)
Egyéb Python beállítási módszerek
There are many set methods, some of which we have already used above. Here is a list of all the methods that are available with the set objects:
Method | Description |
---|---|
add() | Adds an element to the set |
clear() | Removes all elements from the set |
copy() | Returns a copy of the set |
difference() | Returns the difference of two or more sets as a new set |
difference_update() | Removes all elements of another set from this set |
discard() | Removes an element from the set if it is a member. (Do nothing if the element is not in set) |
intersection() | Returns the intersection of two sets as a new set |
intersection_update() | Updates the set with the intersection of itself and another |
isdisjoint() | Returns True if two sets have a null intersection |
issubset() | Returns True if another set contains this set |
issuperset() | Returns True if this set contains another set |
pop() | Removes and returns an arbitrary set element. Raises KeyError if the set is empty |
remove() | Removes an element from the set. If the element is not a member, raises a KeyError |
symmetric_difference() | Returns the symmetric difference of two sets as a new set |
symmetric_difference_update() | Updates a set with the symmetric difference of itself and another |
union() | Returns the union of sets in a new set |
update() | Updates the set with the union of itself and others |
Other Set Operations
Set Membership Test
We can test if an item exists in a set or not, using the in
keyword.
# in keyword in a set # initialize my_set my_set = set("apple") # check if 'a' is present # Output: True print('a' in my_set) # check if 'p' is present # Output: False print('p' not in my_set)
Output
True False
Iterating Through a Set
We can iterate through each item in a set using a for
loop.
>>> for letter in set("apple"):… print(letter)… a p e l
Built-in Functions with Set
Built-in functions like all()
, any()
, enumerate()
, len()
, max()
, min()
, sorted()
, sum()
etc. are commonly used with sets to perform different tasks.
Function | Description |
---|---|
all() | Returns True if all elements of the set are true (or if the set is empty). |
any() | Returns True if any element of the set is true. If the set is empty, returns False . |
enumerate() | Returns an enumerate object. It contains the index and value for all the items of the set as a pair. |
len() | Returns the length (the number of items) in the set. |
max() | Returns the largest item in the set. |
min() | Returns the smallest item in the set. |
sorted() | Returns a new sorted list from elements in the set(does not sort the set itself). |
sum() | Returns the sum of all elements in the set. |
Python Frozenset
A Frozenset egy új osztály, amely rendelkezik egy halmaz jellemzőivel, de elemeit a hozzárendelés után nem lehet megváltoztatni. Míg a sorok változhatatlan listák, addig a frozensek változhatatlan halmazok.
A módosítható készletek nem kezelhetők, ezért nem használhatók szótárkulcsként. Másrészről a frozensetek hashable-k és felhasználhatók egy szótár kulcsaként.
Frozensetek a frozenset () függvény segítségével hozhatók létre.
Ez az adattípus támogatja módszerek tetszik copy()
, difference()
, intersection()
, isdisjoint()
, issubset()
, issuperset()
, symmetric_difference()
és union()
. Mivel változhatatlan, nem rendelkezik olyan módszerekkel, amelyek elemeket adnak hozzá vagy távolítanak el.
# Frozensets # initialize A and B A = frozenset((1, 2, 3, 4)) B = frozenset((3, 4, 5, 6))
Próbálja ki ezeket a példákat a Python shell-en.
>>> A.isdisjoint(B) False >>> A.difference(B) frozenset((1, 2)) >>> A | B frozenset((1, 2, 3, 4, 5, 6)) >>> A.add(3)… AttributeError: 'frozenset' object has no attribute 'add'