Heim Backend-Entwicklung Python-Tutorial Verwendung von Python für die Segmentierung chinesischer Wörter

Verwendung von Python für die Segmentierung chinesischer Wörter

Oct 18, 2016 am 09:18 AM

Zu den Partizipien, die ich derzeit häufig verwende, gehören Stotterpartizipien, NLPIR-Partizipien usw.

Ich verwende in letzter Zeit einige Empfehlungen und sie sind recht einfach zu verwenden.

1. Einführung in die Zhiba-Wortsegmentierung

Bei der Verwendung der Zhiba-Wortsegmentierung für die chinesische Wortsegmentierung gibt es drei grundlegende Implementierungsprinzipien:

Effizientes Wortdiagramm-Scannen basierend auf der Trie-Baumstruktur um chinesische Schriftzeichen in Sätzen zu generieren. Der gerichtete azyklische Graph (DAG), der aus allen möglichen Wortbildungssituationen besteht

, verwendet dynamische Programmierung, um den Pfad mit der maximalen Wahrscheinlichkeit zu finden, und findet die maximale Segmentierungskombination basierend auf der Worthäufigkeit

für nicht registrierte Wörter unter Verwendung des HMM-Modells basierend auf der Fähigkeit chinesischer Schriftzeichen, Wörter zu bilden, unter Verwendung des Viterbi-Algorithmus

2. Installation und Verwendung (Linux)

1. Laden Sie das Tool herunter Paket, entpacken Sie es und geben Sie das Verzeichnis ein, führen Sie Folgendes aus: python setup.py install

Hinweis: a. Es ist eine gute Angewohnheit, die Readme-Datei der heruntergeladenen Software zu lesen, bevor Sie fortfahren. (Wenn Sie die Readme-Datei nicht lesen, versuchen Sie es direkt mit Baidu. Sie werden viele Umwege machen.)

Beim Ausführen des Installationsbefehls ist ein Fehler aufgetreten: Keine Berechtigung! (Bei einigen Leuten kann dieses Problem aufgrund unzureichender Berechtigungen auftreten. Ausführung: sudo !!, wobei „!!“ den vorherigen Befehl bedeutet, hier bezieht es sich auf den Installationsbefehl oben). Nach Verwendung von sudo kann es normal ausgeführt werden.


2. Wenn Sie Jieba für die Wortsegmentierung verwenden, müssen Sie folgende Funktion verwenden: jieba.cut(arg1, arg2); Sie müssen nur die folgenden drei Punkte verstehen, um

verwenden zu können. Die a.cut-Methode akzeptiert zwei Eingabeparameter: Der erste Parameter (arg1) ist die Zeichenfolge, die segmentiert werden muss, und der Parameter arg2 wird zur Steuerung verwendet der Wortsegmentierungsmodus.

Der Wortsegmentierungsmodus ist in zwei Kategorien unterteilt: der Standardmodus, der versucht, den Satz in die genaueste Form zu schneiden, die für die Textanalyse geeignet ist; der vollständige Modus, der alle Wörter im Satz durchsucht das kann in Wörter umgewandelt werden, die für Suchmaschinen geeignet sind

b. Die zu segmentierende Zeichenfolge kann eine GBK-Zeichenfolge, eine UTF-8-Zeichenfolge oder Unicode sein

Personen, die Python verwenden, sollten darauf achten Codierungsprobleme. Wenn Zeichen auftauchen, die nicht zu ASCII gehören (z. B. bei der Verwendung chinesischer Zeichen im Code), wird eine Fehlermeldung angezeigt: „ASCII-Codec kann Zeichen nicht codieren“. um am Anfang der Datei eine Anweisung hinzuzufügen: #! -*- programming:utf- 8 -*- um dem Python-Compiler mitzuteilen: „Meine Datei ist in utf-8 codiert. Wenn Sie dekodieren möchten, verwenden Sie bitte utf- 8." (Denken Sie daran, dass dieser Befehl oben in der Datei hinzugefügt werden muss. Wenn er nicht oben steht, besteht das Codierungsproblem weiterhin und wird nicht gelöst.) Informationen zur Codierungskonvertierung finden Sie im Blog-Beitrag (ps : Persönliches Verständnis von „import sys reload( sys) sys.setdefaultencoding('utf-8')“ Diese Sätze entsprechen „#! -*- programming:utf-8 -*-“)

Das Von c.jieba.cut zurückgegebene Struktur Es handelt sich um einen iterierbaren Generator. Sie können eine for-Schleife verwenden, um jedes nach der Wortsegmentierung erhaltene Wort (Unicode) abzurufen, oder Sie können es mit list(jieba.cut(...)) konvertieren in eine Liste

3. Zum Beispiel eine in jieba bereitgestellte Verwendungsmethode zur Veranschaulichung:

#! -*- coding:utf-8 -*-
import jieba
seg_list = jieba.cut("我来到北京清华大学", cut_all = True)
print "Full Mode:", ' '.join(seg_list)
  
seg_list = jieba.cut("我来到北京清华大学")
print "Default Mode:", ' '.join(seg_list)
Nach dem Login kopieren

Das Ausgabeergebnis ist:

Full Mode: 我/ 来/ 来到/ 到/ 北/ 北京/ 京/ 清/ 清华/ 清华大学/ 华/ 华大/ 大/ 大学/ 学  
Default Mode: 我/ 来到/ 北京/ 清华大学
Nach dem Login kopieren

3. Weitere Funktionen der stotternden chinesischen Wortsegmentierung

1. Benutzerdefinierte Wörterbücher hinzufügen oder verwalten

Alle Wörterbuchinhalte von Stottern werden in dict.txt gespeichert, Sie können den Inhalt in dict.txt weiter verbessern.

2. Schlüsselwortextraktion

Extrahieren Sie Schlüsselwörter, indem Sie das TF/IDF-Gewicht der Schlüsselwörter nach der Wortsegmentierung berechnen.


Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Apr 01, 2025 pm 05:09 PM

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Apr 01, 2025 pm 11:15 PM

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Was sind einige beliebte Python -Bibliotheken und ihre Verwendung? Was sind einige beliebte Python -Bibliotheken und ihre Verwendung? Mar 21, 2025 pm 06:46 PM

In dem Artikel werden beliebte Python-Bibliotheken wie Numpy, Pandas, Matplotlib, Scikit-Learn, TensorFlow, Django, Flask und Anfragen erörtert, die ihre Verwendung in wissenschaftlichen Computing, Datenanalyse, Visualisierung, maschinellem Lernen, Webentwicklung und h beschreiben

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen ohne Serving_forver () an? Apr 01, 2025 pm 10:51 PM

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen an? Uvicorn ist ein leichter Webserver, der auf ASGI basiert. Eine seiner Kernfunktionen ist es, auf HTTP -Anfragen zu hören und weiterzumachen ...

Was sind reguläre Ausdrücke? Was sind reguläre Ausdrücke? Mar 20, 2025 pm 06:25 PM

Regelmäßige Ausdrücke sind leistungsstarke Tools für Musteranpassung und Textmanipulation in der Programmierung, wodurch die Effizienz bei der Textverarbeitung in verschiedenen Anwendungen verbessert wird.

Erklären Sie den Zweck virtueller Umgebungen in Python. Erklären Sie den Zweck virtueller Umgebungen in Python. Mar 19, 2025 pm 02:27 PM

Der Artikel erörtert die Rolle virtueller Umgebungen in Python und konzentriert sich auf die Verwaltung von Projektabhängigkeiten und die Vermeidung von Konflikten. Es beschreibt ihre Erstellung, Aktivierung und Vorteile bei der Verbesserung des Projektmanagements und zur Verringerung der Abhängigkeitsprobleme.

Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Wie erstelle ich dynamisch ein Objekt über eine Zeichenfolge und rufe seine Methoden in Python auf? Apr 01, 2025 pm 11:18 PM

Wie erstellt in Python ein Objekt dynamisch über eine Zeichenfolge und ruft seine Methoden auf? Dies ist eine häufige Programmieranforderung, insbesondere wenn sie konfiguriert oder ausgeführt werden muss ...

See all articles