Πώς να φιλτράρετε μια λίστα συμβολοσειρών στο Python

How Filter List Strings Python



Η Python χρησιμοποιεί τον τύπο δεδομένων λίστας για την αποθήκευση πολλαπλών δεδομένων σε ένα διαδοχικό ευρετήριο. Λειτουργεί σαν μια αριθμητική συστοιχία άλλων γλωσσών προγραμματισμού. Η μέθοδος filter () είναι μια πολύ χρήσιμη μέθοδος της Python. Μία ή περισσότερες τιμές δεδομένων μπορούν να φιλτραριστούν από οποιαδήποτε συμβολοσειρά ή λίστα ή λεξικό στην Python χρησιμοποιώντας τη μέθοδο φίλτρου (). Φιλτράρει δεδομένα με βάση οποιαδήποτε συγκεκριμένη συνθήκη. Αποθηκεύει δεδομένα όταν η συνθήκη επιστρέφει true και απορρίπτει δεδομένα όταν επιστρέφει false. Ο τρόπος με τον οποίο μπορούν να φιλτραριστούν τα δεδομένα συμβολοσειράς σε μια λίστα σε Python φαίνεται σε αυτό το άρθρο χρησιμοποιώντας διαφορετικά παραδείγματα. Πρέπει να χρησιμοποιήσετε το Python 3+ για να δοκιμάσετε τα παραδείγματα αυτού του άρθρου.

Φιλτράρετε μια λίστα συμβολοσειρών χρησιμοποιώντας μια άλλη λίστα

Αυτό το παράδειγμα δείχνει πώς μπορούν να φιλτραριστούν τα δεδομένα σε μια λίστα συμβολοσειρών χωρίς να χρησιμοποιηθεί καμία μέθοδος. Η λίστα της συμβολοσειράς φιλτράρεται εδώ χρησιμοποιώντας μια άλλη λίστα. Εδώ, δύο μεταβλητές λίστας δηλώνονται με το όνομα λίστα 1 και λίστα 2 Το Οι αξίες του λίστα 2 φιλτράρεται χρησιμοποιώντας τις τιμές του λίστα 1 Το Το σενάριο θα ταιριάζει με την πρώτη λέξη κάθε τιμής του λίστα 2 με τις αξίες του λίστα 1 και εκτυπώστε τις τιμές που δεν υπάρχουν στο λίστα 1 Το







# Δηλώστε δύο μεταβλητές λίστας
λίστα 1= ['Perl', 'PHP', 'Ιάβα', 'ΑΣΠΙΔΑ']
λίστα 2= ['Η JavaScript είναι γλώσσα δέσμης ενεργειών από την πλευρά του πελάτη',
'Η PHP είναι μια γλώσσα δέσμης ενεργειών από την πλευρά του διακομιστή',
«Η Java είναι γλώσσα προγραμματισμού»,
'Το Bash είναι γλώσσα δέσμης ενεργειών']

# Φιλτράρετε τη δεύτερη λίστα με βάση την πρώτη λίστα
data_ filter= [ΧΓιαΧσελίστα 2αν
όλα(καιδεν σεΧΓιακαισελίστα 1)]

# Εκτύπωση δεδομένων λίστας πριν από το φίλτρο και μετά το φίλτρο
Τυπώνω('Το περιεχόμενο της πρώτης λίστας:',λίστα 1)
Τυπώνω('Το περιεχόμενο της δεύτερης λίστας:',λίστα 2)
Τυπώνω('Το περιεχόμενο της δεύτερης λίστας μετά το φίλτρο:',data_ filter)

Παραγωγή:



Εκτελέστε το σενάριο. Εδώ, λίστα 1 δεν περιέχει τη λέξη « Κτυπώ δυνατά ’. Η έξοδος θα περιέχει μόνο μία τιμή από λίστα 2 αυτό είναι ' Το Bash είναι γλώσσα δέσμης ενεργειών » Το







Φιλτράρετε μια λίστα συμβολοσειρών χρησιμοποιώντας άλλη λίστα και προσαρμοσμένη συνάρτηση

Αυτό το παράδειγμα δείχνει πώς μια λίστα συμβολοσειρών μπορεί να φιλτραριστεί χρησιμοποιώντας μια άλλη λίστα και τη συνάρτηση προσαρμοσμένου φίλτρου. Το σενάριο περιέχει δύο μεταβλητές λίστας που ονομάζονται list1 και list2. Η συνάρτηση προσαρμοσμένου φίλτρου θα ανακαλύψει τις κοινές τιμές και των δύο μεταβλητών λίστας.

# Δηλώστε δύο μεταβλητές λίστας
λίστα 1= ['90', '67', '3. 4', '55', '12', '87', '32']
λίστα 2= ['9', '90', '38', 'Τέσσερα πέντε', '12', 'είκοσι']

# Δηλώστε τη λειτουργία φιλτραρίσματος δεδομένων από την πρώτη λίστα
defΦίλτρο(λίστα 1,λίστα 2):
ΕΠΙΣΤΡΟΦΗ [νΓιανσελίστα 1αν
όποιος(ΜσενΓιαΜσελίστα 2)]

# Εκτυπώστε τα δεδομένα της λίστας πριν από το φίλτρο και μετά το φίλτρο
Τυπώνω('Το περιεχόμενο της λίστας1:',λίστα 1)
Τυπώνω('Το περιεχόμενο της λίστας2:',λίστα 2)
Τυπώνω('Τα δεδομένα μετά το φίλτρο',Φίλτρο(λίστα 1,λίστα 2))

Παραγωγή:



Εκτελέστε το σενάριο. Υπάρχουν τιμές 90 και 12 και στις δύο μεταβλητές λίστας. Η ακόλουθη έξοδος θα δημιουργηθεί μετά την εκτέλεση του σεναρίου.

Φιλτράρετε μια λίστα συμβολοσειρών χρησιμοποιώντας κανονική έκφραση

Η λίστα φιλτράρεται με τη χρήση όλα() και όποιος() μεθόδους στα δύο προηγούμενα παραδείγματα. Μια κανονική έκφραση χρησιμοποιείται σε αυτό το παράδειγμα για να φιλτράρει τα δεδομένα από μια λίστα. Μια κανονική έκφραση είναι ένα μοτίβο με το οποίο μπορούν να αναζητηθούν ή να αντιστοιχιστούν οποιαδήποτε δεδομένα. 'σχετικά με' Το module χρησιμοποιείται στην python για την εφαρμογή κανονικής έκφρασης στο σενάριο. Εδώ, δηλώνεται μια λίστα με κωδικούς θέματος. Μια κανονική έκφραση χρησιμοποιείται για να φιλτράρει εκείνους τους κωδικούς θέματος που ξεκινούν με τη λέξη, « ΧΑΚ '. ' ^ Το σύμβολο χρησιμοποιείται σε κανονικά μοτίβα έκφρασης για αναζήτηση στην αρχή του κειμένου.

# Εισαγωγή νέας μονάδας για χρήση κανονικής έκφρασης
εισαγωγή σχετικά με

# Δηλώστε ότι η λίστα περιέχει κωδικό θέματος
υποκατάλογος= ['CSE-407', 'PHY-101', 'CSE-101', «ENG-102», 'MAT-202']

# Δηλώστε τη λειτουργία φίλτρου
defΦίλτρο(κατάλογος δεδομένων):
# Αναζήτηση δεδομένων με βάση την κανονική έκφραση της λίστας
ΕΠΙΣΤΡΟΦΗ [ωρεςΓιαωρεςσεκατάλογος δεδομένων
αν σχετικά μεΤοΑναζήτηση(ρ'^ ΧΑΚ',ωρες)]

# Εκτυπώστε τα δεδομένα φίλτρου
Τυπώνω(Φίλτρο(υποκατάλογος))

Παραγωγή:

Εκτελέστε το σενάριο. υποκατάλογος η μεταβλητή περιέχει δύο τιμές που ξεκινούν με ' ΧΑΚ ’. Η ακόλουθη έξοδος θα εμφανιστεί μετά την εκτέλεση του σεναρίου.

Φιλτράρετε μια λίστα συμβολοσειρών χρησιμοποιώντας την έκφραση lamda

Αυτό το παράδειγμα δείχνει τη χρήση του λάμδα έκφραση για φιλτράρισμα δεδομένων από μια λίστα συμβολοσειρών. Εδώ, μια μεταβλητή λίστας με όνομα λέξη_αναζήτησης χρησιμοποιείται για το φιλτράρισμα περιεχομένου από μια μεταβλητή κειμένου που ονομάζεται κείμενο Το Το περιεχόμενο του κειμένου μετατρέπεται σε μια λίστα με το όνομα, λέξη_κείμενο με βάση το χώρο χρησιμοποιώντας διαίρεση() μέθοδος. λάμδα η έκφραση θα παραλείψει αυτές τις τιμές από το λέξη_κείμενο που υπάρχουν στο λέξη_αναζήτησης και αποθηκεύστε τις φιλτραρισμένες τιμές σε μια μεταβλητή προσθέτοντας χώρο.

# Δηλώστε μια λίστα που περιέχει τη λέξη αναζήτησης
λέξη_αναζήτησης= ['Διδάσκω', 'Κώδικας', 'Προγραμματισμός', 'Ιστολόγιο']

# Ορίστε το κείμενο στο οποίο θα αναζητηθεί η λέξη από τη λίστα
κείμενο= «Μάθετε προγραμματισμό Python από το Linux Hint Blog»

# Διαχωρίστε το κείμενο με βάση το διάστημα και αποθηκεύστε τις λέξεις σε μια λίστα
λέξη_κείμενο=κείμενο.διαίρεση()

# Χρησιμοποιώντας λάμδα έκφραση φιλτράρετε τα δεδομένα
filter_text= ''ΤοΣυμμετοχή((φίλτρο(λάμδαβαλ: βαλδενΕγώ
n λέξη_αναζήτησης,λέξη_κείμενο)))

# Εκτύπωση κειμένου πριν από το φιλτράρισμα και μετά το φιλτράρισμα
Τυπώνω(' nΚείμενο πριν το φιλτράρισμα: n',κείμενο)
Τυπώνω(«Κείμενο μετά το φιλτράρισμα: n',filter_text)

Παραγωγή:

Εκτελέστε το σενάριο. Η ακόλουθη έξοδος θα εμφανιστεί μετά την εκτέλεση του σεναρίου.

Φιλτράρετε μια λίστα συμβολοσειρών χρησιμοποιώντας τη μέθοδο φίλτρου ()

φίλτρο() Η μέθοδος δέχεται δύο παραμέτρους. Η πρώτη παράμετρος παίρνει ένα όνομα συνάρτησης ή Κανένας και η δεύτερη παράμετρος παίρνει το όνομα της μεταβλητής λίστας ως τιμές. φίλτρο() η μέθοδος αποθηκεύει αυτά τα δεδομένα από τη λίστα εάν επιστρέψει true, διαφορετικά, απορρίπτει τα δεδομένα. Εδώ, Κανένας δίνεται ως τιμή πρώτης παραμέτρου. Όλες οι τιμές χωρίς ψευδής θα ανακτηθούν από τη λίστα ως φιλτραρισμένα δεδομένα.

# Δηλώστε μια λίστα δεδομένων μείξης
listData= ['Γεια σας', 200, 1, 'Κόσμος', Ψευδής, Αληθής, '0']

# Μέθοδος φίλτρου κλήσης () με Καμία και λίστα
φιλτραρισμένοΔεδομένα= φίλτρο(Κανένας,listData)

# Εκτυπώστε τη λίστα μετά το φιλτράρισμα των δεδομένων
Τυπώνω('Η λίστα μετά το φιλτράρισμα:')
ΓιαωρεςσεφιλτραρισμένοΔεδομένα:
Τυπώνω(ωρες)

Παραγωγή:

Εκτελέστε το σενάριο. Η λίστα περιέχει μόνο μία ψευδή τιμή που θα παραλειφθεί στα φιλτραρισμένα δεδομένα. Η ακόλουθη έξοδος θα εμφανιστεί μετά την εκτέλεση του σεναρίου.

Συμπέρασμα:

Το φιλτράρισμα είναι χρήσιμο όταν πρέπει να αναζητήσετε και να ανακτήσετε συγκεκριμένες τιμές από μια λίστα. Ελπίζω ότι τα παραπάνω παραδείγματα θα βοηθήσουν τους αναγνώστες να κατανοήσουν τους τρόπους φιλτραρίσματος δεδομένων από μια λίστα συμβολοσειρών.