Преобразование HTML в обычный текст в Java
Мне нужно преобразовать HTML в обычный текст. Мое единственное требование форматирования - сохранить новые строки в тексте. Новые строки должны отображаться не только в случае <br> , но другие теги, например. < tr/" > , </p> приводит к новой строке.
Примеры HTML-страниц для тестирования: "http://www.particle.kth.se/~lindsey/JavaCourse/Book/Part1/Java/Chapter09/scannerConsole.html" или "http://www.javadb. com/write-to-file-using-bufferedwriter". Обратите внимание, что это только случайные URL-адреса.
Я опробовал различные библиотеки (JSoup, Javax.swing, Apache utils), упомянутые в следующем потоке для преобразования HTML в обычный текст.
Ссылка: "http://stackoverflow.com/info/240546/removing-html-from-a-java-string"
Пример использования JSoup:
public class JSoupTest {
@Test
public void SimpleParse() {
try {
Document doc = Jsoup.connect("http://www.particle.kth.se/~lindsey/JavaCourse/Book/Part1/Java/Chapter09/scannerConsole.html").get();
System.out.print(doc.text());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Пример с HTMLEditorKit:
import javax.swing.text.html.*;
import javax.swing.text.html.parser.*;
public class Html2Text extends HTMLEditorKit.ParserCallback {
StringBuffer s;
public Html2Text() {}
public void parse(Reader in) throws IOException {
s = new StringBuffer();
ParserDelegator delegator = new ParserDelegator();
// the third parameter is TRUE to ignore charset directive
delegator.parse(in, this, Boolean.TRUE);
}
public void handleText(char[] text, int pos) {
s.append(text);
}
public String getText() {
return s.toString();
}
public static void main (String[] args) {
try {
// the HTML to convert
URL url = new URL("http://www.javadb.com/write-to-file-using-bufferedwriter");
URLConnection conn = url.openConnection();
BufferedReader reader = new BufferedReader(new InputStreamReader(url.openStream()));
String inputLine;
String finalContents = "";
while ((inputLine = reader.readLine()) != null) {
finalContents += "\n" + inputLine.replace("<br", "\n<br");
}
BufferedWriter writer = new BufferedWriter(new FileWriter("samples/testHtml.html"));
writer.write(finalContents);
writer.close();
FileReader in = new FileReader("samples/testHtml.html");
Html2Text parser = new Html2Text();
parser.parse(in);
in.close();
System.out.println(parser.getText());
}
catch (Exception e) {
e.printStackTrace();
}
}
}
Ответы
Ответ 1
Попросите ваш парсер добавить текстовый контент и новые строки в StringBuilder.
final StringBuilder sb = new StringBuilder();
HTMLEditorKit.ParserCallback parserCallback = new HTMLEditorKit.ParserCallback() {
public boolean readyForNewline;
@Override
public void handleText(final char[] data, final int pos) {
String s = new String(data);
sb.append(s.trim());
readyForNewline = true;
}
@Override
public void handleStartTag(final HTML.Tag t, final MutableAttributeSet a, final int pos) {
if (readyForNewline && (t == HTML.Tag.DIV || t == HTML.Tag.BR || t == HTML.Tag.P)) {
sb.append("\n");
readyForNewline = false;
}
}
@Override
public void handleSimpleTag(final HTML.Tag t, final MutableAttributeSet a, final int pos) {
handleStartTag(t, a, pos);
}
};
new ParserDelegator().parse(new StringReader(html), parserCallback, false);
Ответ 2
Я бы предположил, что вы можете использовать ParserCallback.
Вам нужно будет добавить код для поддержки тегов, требующих специальной обработки. Есть:
- handleStartTag
- handleEndTag
- handleSimpleTag
который позволит вам проверить теги, которые вы хотите контролировать, а затем добавить символ новой строки в свой буфер.
Ответ 3
Основываясь на вашем примере с подсказкой html на обычный текст? сообщение:
import java.io.*;
import org.jsoup.*;
import org.jsoup.nodes.*;
public class TestJsoup
{
public void SimpleParse()
{
try
{
Document doc = Jsoup.connect("http://www.particle.kth.se/~lindsey/JavaCourse/Book/Part1/Java/Chapter09/scannerConsole.html").get();
// Trick for better formatting
doc.body().wrap("<pre></pre>");
String text = doc.text();
// Converting nbsp entities
text = text.replaceAll("\u00A0", " ");
System.out.print(text);
}
catch (IOException e)
{
e.printStackTrace();
}
}
public static void main(String args[])
{
TestJsoup tjs = new TestJsoup();
tjs.SimpleParse();
}
}
Ответ 4
Вы можете использовать XSLT для этой цели. Посмотрите эту ссылку, которая касается аналогичной проблемы.
Надеюсь, что это будет полезно.
Ответ 5
Я бы использовал SAX. Если ваш документ не является хорошо сформированным XHTML, я бы преобразовал его с помощью JTidy.