두 개 이상의 단어를 검사 할 수 있고 Java 지식이 너무 제한되어 직접 변경하기 위해이 스크립트를 수정해야합니다. 이 스크립트는 OpenOffice (LanguageTool)의 opensource 문법 검사기의 일부이며 스크립트 목적은 특정 단어를 다른 단어로 바꾸는 것입니다.이 자바 코드에서 두 개 이상의 단어를 검사하는 방법
확인하는 단어의 파일은 "coherency.txt"라고하고 형식의되고이 같다 : WrongWord1 = CorrectWord1 WrongWord2 = CorrectWord2
을 내가 입력 할 때 : WrongWord1이 스크립트에 의해 플래그되고 대신 CorrectWord1을 사용해야한다고 알려줍니다. 내가 WrongWord3를 입력 할 때 은 그게
입니다 WrongWord1 = WrongWord2 = CorrectWord1 WrongWord3 = WrongWord4 = WrongWord5 = CorrectWord2 WrongWord6 = CorrectWord3 그래서 :
는하지만 다음과 같이 세 단어 이상을 할 수 있어야합니다 플래그 및 스크립트 내가 그것을 또한 플래그가 WrongWord2를 입력하고 스크립트는 내가 http://www.sbbic.org/lang/en-us/volunteer/
0123에서 웹 페이지로 연결되는 링크를 넣을 수 있습니다 도움이 될 수 있다면 나는 CorrectWord1를 사용해야 저를 말할 때 내가 CorrectWord2 또는 를 사용해야 하더군요
이 코드를 수정하여 둘 이상의 단어를 비교 한 결과 대체 할 수있는 방법에 대해 도움을 주시면 대단히 감사하겠습니다! 감사 네이 작은 적응 용
/* LanguageTool, a natural language style checker
* Copyright (C) 2005 Daniel Naber (http://www.danielnaber.de)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301
* USA
*/
package de.danielnaber.languagetool.rules;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.ResourceBundle;
import de.danielnaber.languagetool.AnalyzedSentence;
import de.danielnaber.languagetool.AnalyzedTokenReadings;
import de.danielnaber.languagetool.JLanguageTool;
import de.danielnaber.languagetool.tools.StringTools;
/**
* A Khmer rule that matches words or phrases which should not be used and suggests
* correct ones instead. Loads the relevant words from
* <code>rules/km/coherency.txt</code>, where km is a code of the language.
*
* @author Andriy Rysin
*/
public abstract class KhmerWordCoherencyRule extends KhmerRule {
private Map<String, String> wrongWords; // e.g. "вреѿті реѿт" -> "зреѿтою"
private static final String FILE_NAME = "/km/coherency.txt";
public abstract String getFileName();
private static final String FILE_ENCODING = "utf-8";
public String getEncoding() {
return FILE_ENCODING;
}
/**
* Indicates if the rule is case-sensitive. Default value is <code>true</code>.
* @return true if the rule is case-sensitive, false otherwise.
*/
public boolean isCaseSensitive() {
return false;
}
/**
* @return the locale used for case conversion when {@link #isCaseSensitive()} is set to <code>false</code>.
*/
public Locale getLocale() {
return Locale.getDefault();
}
public KhmerWordCoherencyRule(final ResourceBundle messages) throws IOException {
if (messages != null) {
super.setCategory(new Category(messages.getString("category_misc")));
}
wrongWords = loadWords(JLanguageTool.getDataBroker().getFromRulesDirAsStream(getFileName()));
}
public String getId() {
return "KM_WORD_COHERENCY";
}
public String getDescription() {
return "Checks for wrong words/phrases";
}
public String getSuggestion() {
return " is not valid, use ";
}
public String getShort() {
return "Wrong word";
}
public final RuleMatch[] match(final AnalyzedSentence text) {
final List<RuleMatch> ruleMatches = new ArrayList<RuleMatch>();
final AnalyzedTokenReadings[] tokens = text.getTokensWithoutWhitespace();
for (int i = 1; i < tokens.length; i++) {
final String token = tokens[i].getToken();
final String origToken = token;
final String replacement = isCaseSensitive()?wrongWords.get(token):wrongWords.get(token.toLowerCase(getLocale()));
if (replacement != null) {
final String msg = token + getSuggestion() + replacement;
final int pos = tokens[i].getStartPos();
final RuleMatch potentialRuleMatch = new RuleMatch(this, pos, pos
+ origToken.length(), msg, getShort());
if (!isCaseSensitive() && StringTools.startsWithUppercase(token)) {
potentialRuleMatch.setSuggestedReplacement(StringTools.uppercaseFirstChar(replacement));
} else {
potentialRuleMatch.setSuggestedReplacement(replacement);
}
ruleMatches.add(potentialRuleMatch);
}
}
return toRuleMatchArray(ruleMatches);
}
private Map<String, String> loadWords(final InputStream file) throws IOException {
final Map<String, String> map = new HashMap<String, String>();
InputStreamReader isr = null;
BufferedReader br = null;
try {
isr = new InputStreamReader(file, getEncoding());
br = new BufferedReader(isr);
String line;
while ((line = br.readLine()) != null) {
line = line.trim();
if (line.length() < 1) {
continue;
}
if (line.charAt(0) == '#') { // ignore comments
continue;
}
final String[] parts = line.split("=");
if (parts.length != 2) {
throw new IOException("Format error in file "
+ JLanguageTool.getDataBroker().getFromRulesDirAsUrl(getFileName()) + ", line: " + line);
}
map.put(parts[0], parts[1]);
}
} finally {
if (br != null) {
br.close();
}
if (isr != null) {
isr.close();
}
}
return map;
}
public void reset() {
}
}
당신은 너무 많은 코드를 기록했다. 문제를 나타내는 코드를 게시하십시오. 네 문제가 뭔지도 모르겠다. – Falmarri
누군가가 묻는 것을하면, 조정 된 소스 코드를 컴파일 할 수있는 전문 지식을 갖추고 있으며, 필요한 경우 컴파일 된 모든 소스를 JAR 파일에 다시 패키징합니까? 조정 된 소스를 대체하여 간단하게 "작동"하지 않기 때문입니다. –
당신은 * word1 = wrongword2 *와 같고 * wrongword2 = word1 *이 아닌 것이 확실합니까? – Hons