Haskell:
Reguläre Ausdrücke verwenden
Wie:
In Haskell sind Regex-Funktionalitäten nicht Teil der Standardbibliothek, was die Verwendung von Drittanbieterpaketen wie regex-base
zusammen mit einem kompatiblen Backend wie regex-posix
(für POSIX-Regex-Unterstützung), regex-pcre
(für Perl-kompatible Regex) usw. erforderlich macht. So können Sie diese Pakete verwenden, um mit regulären Ausdrücken zu arbeiten.
Stellen Sie zunächst sicher, dass Sie die Pakete installiert haben, indem Sie regex-posix
oder regex-pcre
zur .cabal
-Datei Ihres Projekts hinzufügen oder direkt über cabal installieren:
cabal install regex-posix
oder
cabal install regex-pcre
Verwendung von regex-posix
:
import Text.Regex.Posix ((=~))
-- Überprüfen, ob eine Zeichenkette einem Muster entspricht
isMatch :: String -> String -> Bool
isMatch text pattern = text =~ pattern :: Bool
-- Finde die erste Übereinstimmung
findFirst :: String -> String -> String
findFirst text pattern = text =~ pattern :: String
main :: IO ()
main = do
print $ isMatch "hallo welt" "wo"
-- Ausgabe: True
print $ findFirst "guten Morgen, gute Nacht" "gut"
-- Ausgabe: "gut"
Verwendung von regex-pcre
:
import Text.Regex.PCRE ((=~))
-- Finde alle Übereinstimmungen
findAll :: String -> String -> [String]
findAll text pattern = text =~ pattern :: [String]
main :: IO ()
main = do
print $ findAll "test1 test2 test3" "\\btest[0-9]\\b"
-- Ausgabe: ["test1","test2","test3"]
Jede Bibliothek hat ihre Besonderheiten, aber die allgemeine Methodik, =~
zu verwenden, um das Regex anzuwenden, bleibt konsistent, ob es nun darum geht, auf eine Übereinstimmung zu überprüfen oder Unterzeichenketten zu extrahieren. Die Wahl zwischen regex-posix
oder regex-pcre
hängt weitgehend von den Bedürfnissen Ihres Projekts und den spezifischen erforderlichen Regex-Fähigkeiten ab.