0

私はプロジェクトに取り組んでおり、問題が発生しました。HTMLクリーナーを使用してhtmlを解析し、xpathを使用して文字列を返そうとしています。エラーが見つかった場合はスタックトレースを返すようにしました(エラーが発生しました)。スタックトレースに基づいてデバッグする方法が本当にわかりません。これがコードです。

package ru.habrahabr.stackparser;

import java.net.URL;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import org.htmlcleaner.TagNode;

import android.app.Activity;
import android.app.ProgressDialog;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.*;

public class stackParser extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    Button button = (Button) findViewById(R.id.parse);
    button.setOnClickListener(myListener);
}


private ProgressDialog pd;

private OnClickListener myListener = new OnClickListener() {
    public void onClick(View v) {
        pd = ProgressDialog.show(stackParser.this, "Working...",
                "request to server", true, false);
        new parseSite()
                .execute("http://wiki.teamliquid.net/starcraft2/3_Gate_Robo");
    }
};

private class parseSite extends AsyncTask<String, Void, String> {
    protected String doInBackground(String... arg) {
        String output = new String();
        try {
            htmlHelper hh = new htmlHelper(new URL(arg[0]));
            output = hh.htmlHelper(arg[0]);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return output;
    }


    protected void onPostExecute(String output) {
        pd.dismiss();
        TextView view = (TextView) findViewById(R.id.tv1);
        view.setText(output);

    }
}

これが私のHTMLヘルパークラスです

package ru.habrahabr.stackparser;

import java.io.IOException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import org.htmlcleaner.CleanerProperties;
import org.htmlcleaner.HtmlCleaner;
import org.htmlcleaner.TagNode;
import org.htmlcleaner.XPatherException;

public class htmlHelper {
TagNode rootNode;

public htmlHelper(URL url) {
    // TODO Auto-generated constructor stub
}

public String htmlHelper(String arg) throws IOException, XPatherException
{
    CleanerProperties props = new CleanerProperties();

    // set some properties to non-default values
    props.setTranslateSpecialEntities(true);
    props.setTransResCharsToNCR(true);
    props.setOmitComments(true);

    HtmlCleaner cleaner = new HtmlCleaner(props);
    rootNode = cleaner.clean(arg);

    Object[] nodes = rootNode.evaluateXPath("//h1[@id='firstHeading']");

    String things = nodes.toString();

    return things;
}

UI と読み込みバーは正常に動作しますが、TextView は [Ljava.lang.Object;@42455a88 を返し続けます。

これについての助けを本当に感謝しています...私は一日中それに取り組んでいて、それを理解できないようです. ありがとう!

4

2 に答える 2

0

私はそれを考え出した。Xpathクエリは、XMLドキュメントのDOMツリーを参照していました。したがって、スローを回避するには、クリーニング後にDOMツリーを初期化する必要があります。その後、Xpathが機能します。

于 2013-01-12T02:12:26.693 に答える
0

からテキストを読み取ってみてくださいTagNode:

Object[] nodes = rootNode.evaluateXPath("//h1[@id='firstHeading']");
if(nodes == null || nodes.length < 1) {
    return "";
}

TagNode tagnode = (TagNode)nodes[0];
String things = tagnode.getText();
于 2013-01-11T03:39:09.123 に答える