使用jsoup从网站解析数据

时间:2013-01-07 10:32:40

标签: java jsoup

我正在创建一个Android应用程序,它从www.zamboangatoday.ph收集数据,获取所有新闻标题或标题。但我只能检索一个项目,有人可以检查我的代码。

protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);



            try{

                outputTextView = (TextView)findViewById(R.id.textView1);
                //Document doc = Jsoup.parse(html,"http://www.zamboangatoday.ph");
                Document doc = Jsoup.connect("http://www.zamboangatoday.ph/").get();
                //Elements tag = doc.select(".even h4 a");

                Iterator<Element> iter = doc.select("li.even h4 a").iterator();
                //List<Image> images = new ArrayList<Image>();
                while(iter.hasNext())
                {
                    Element element = iter.next();

                    outputTextView.setText(element.text());

                }

            }catch(Exception e)
            {
                e.printStackTrace();
            }




    }

1 个答案:

答案 0 :(得分:1)

不知道组件outputTextView是什么,但使用此代码:

outputTextView.setText(element.text());

您将设置文本,并在每次迭代时覆盖。因此,在循环之后,将只有最后的元素文本。如果可能,请使用outputTextView.append(element.text());之类的内容 - 否则请使用StringBuilder并在循环后设置文本。


outputTextView = (TextView)findViewById(R.id.textView1);
//Document doc = Jsoup.parse(html,"http://www.zamboangatoday.ph");
Document doc = Jsoup.connect("http://www.zamboangatoday.ph/").get();
//Elements tag = doc.select(".even h4 a");

Iterator<Element> iter = doc.select("li.even h4 a").iterator();
//List<Image> images = new ArrayList<Image>();
while(iter.hasNext())
{
    Element element = iter.next();

    /*
     * Append the text - don't overwrite it
     * Node: Maybe you have to add a new line ('\n').
     */
    outputTextView.append(element.text()); 

}