Ich möchte NN oder NNS aus einem Beispieltext wie im folgenden Skript angegeben erhalten. Zu diesem Zweck, wenn ich den Code unten verwenden, ist die Ausgabe:Wie bekomme ich NN und NNS von einem Text?
types
synchronization
phase
synchronization
-RSB-
synchronization
-LSB-
-RSB-
projection
synchronization
Hier warum ich erhalte [-RSB-]
oder [-LSB-]
? Sollte ich ein anderes Muster verwenden, um NN oder NNS gleichzeitig zu bekommen?
atic = "So far, many different types of synchronization have been investigated, such as complete synchronization [8], generalized synchronization [9], phase synchronization [10], lag synchronization [11], projection synchronization [12, 13], and so forth.";
Reader reader = new StringReader(atic);
DocumentPreprocessor dp = new DocumentPreprocessor(reader);
docs_terms_unq.put(rs.getString("u"), new ArrayList<String>());
docs_terms.put(rs.getString("u"), new ArrayList<String>());
for (List<HasWord> sentence : dp) {
List<TaggedWord> tagged = tagger.tagSentence(sentence);
GrammaticalStructure gs = parser.predict(tagged);
Tree x = parserr.parse(sentence);
System.out.println(x);
TregexPattern NPpattern = TregexPattern.compile("@NN|NNS");
TregexMatcher matcher = NPpattern.matcher(x);
while (matcher.findNextMatchingNode()) {
Tree match = matcher.getMatch();
ArrayList hh = match.yield();
Boolean b = false;
System.out.println(hh.toString());}
Ihnen sehr danken. Ich habe in der Tat erkannt, dass bei Verwendung meiner früheren Vorgehensweise weniger Nomen verwendet wurden! –
Eine kleine Frage. Sollte ich den gleichen Ansatz verwenden, wenn NP gewünscht wird? Für den, den ich gepostet habe, verwende ich ihn wie TregexPattern.compile ("@ NP! << @NP"). Kann ich partOfSpeechTag.equals ("@ NP! << @NP") verwenden? –