繁体   English   中英

Java (Android) Html 表解析到数据库 (SQLite)

[英]Java (Android) Html Table Parsing to Database (SQLite)

我已经搜索了很多天,现在试图找到以下问题的答案。 我对 Java 和 Android 编程还很陌生,并且主要从复制粘贴编辑场景中学习,但尽管有一些教程,但我真的很挣扎这个。

我已经尝试将 htmlcleaner 作为我的解析器,我确信我已经接近了,但只是无法做到这一点。

我正在尝试将网站上的值表(即<TR>TD,TD,TD,TD</TR> )解析为标准 Android SQLite 数据库。 所以表的每一行都是数据库中的一行。

从理论上讲,这应该很简单,但是我被不同的方法弄得不知所措,而且不了解一种简单干净的方法。

有人可以帮忙吗? 请不要将我指向 htmlparser 或非特定教程,因为我已经在这些领域工作了很长时间并且无法管理解决方案。

我要解析的表值在这里: Teams and values

编辑:::

好的,我想我正在接近使用 JSoup。 我可以从 [td] 标记中获取一个值并将其放入一个字符串中。 但是,如何调整以下代码,以便为每个“for”迭代每一行(即在每个 [tr] 内),并将每个 [td] 值放入字符串数组?

public class GetTable extends Activity {

static String hello;


@Override
public void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
    setContentView(R.layout.testlayout);
try {
    populateTexts();
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}
}

    private void populateTexts() throws IOException{
    String url =     "http://news.bbc.co.uk/mobile/bbc_sport/rugby/competition/ru100/table/index.shtml?context=cps_ukfs";

    Document doc = Jsoup.connect(url).get();
  Elements links = doc.select("td");


    for (Element link : links) {
        hello = link.text();
        TextView twittertext10 = (TextView)findViewById(R.id.testView1);
        twittertext10.setText(hello);
    }
    }
}

解决方法如下。 我将数据库 output 放到一个列表视图中,只是为了显示我拥有所有正确的数据。

public class GetTable extends ListActivity {

static String team;
static int played;
static int won;
static int drew;
static int points;
private TableDbAdapter mDbHelper;
static int position = 0;


@Override
public void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
    setContentView(R.layout.testlayout);
    mDbHelper = new TableDbAdapter(this);
       mDbHelper.open();
    mDbHelper.clearTable();
try {
    populateTexts();
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}
populateList();
}

    private void populateTexts() throws IOException{
    String url =     "http://news.bbc.co.uk/mobile/bbc_sport/rugby/competition/ru100/table/index.shtml?    context=cps_ukfs";

    Document doc = Jsoup.connect(url).get();

    //

  Elements rows = doc.select("table[class=tblResults teamTable] tr:gt(0):lt(13)");

        String s[] = new String[rows.size()];
        for(Element row : rows){
            s[0] = row.child(0).text();
            s[1] = row.child(1).text();
            s[2] = row.child(2).text();
            s[3] = row.child(3).text();
            s[4] = row.child(4).text();

        team = s[0];
        if (s[1] !=""){
        played = Integer.parseInt(s[1]);}
        else played = 0;
        if (s[2] !=""){
        won = Integer.parseInt(s[2]);}
        else won = 0;
        if (s[3] !=""){
        drew = Integer.parseInt(s[3]);}
        else drew = 0;
        if (s[4] !=""){
        points = Integer.parseInt(s[4]);}
        else points = 0;

        position ++;


    // sql insert
       mDbHelper.createTableRow(position, team, played, won, drew, points);



    }
    }

    private void populateList() {
           // Get all of the fixtures from the database and create the item list
           Cursor c = mDbHelper.fetchWholeTable();
           startManagingCursor(c);

           String[] from = new String[] { TableDbAdapter.KEY_POSITION, TableDbAdapter.KEY_TEAM, TableDbAdapter.KEY_PLAYED, TableDbAdapter.KEY_WINS, TableDbAdapter.KEY_DREW, TableDbAdapter.KEY_POINTS};
           int[] to = new int[] { R.id.fixtextlist, R.id.fixtextlistkotime, R.id.fixtextlisthome, R.id.fixtextlisths, R.id.fixtextlistas, R.id.fixtextlistaway};

           // Now create an array adapter and set it to display using our row
           SimpleCursorAdapter table =
               new SimpleCursorAdapter(this, R.layout.fixlist_item, c, from, to);
           setListAdapter(table);




       }
}

您可能最好使用 SAX 或其他一些 XML 解析器来解析您的表数据,然后从那里使用 SQLIteDatabaseHelper class 来制作一个表并插入您的数据。 如果您有更具体的问题,我会尝试给出更具体的答案:-)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM