私はAndroidに少し慣れていないので、Jsoupを使用してWebサイトからデータを取得しようとしています. これは私がJavaプロジェクトで使用した正確なコードで、うまくいきました。しかし、Androidに転送して「println」を「setText()」に変更すると、アプリが「予期せず停止」します。
package com.ex.myschoolapp;
import java.io.IOException;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.select.Elements;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.widget.TextView;
public class MainActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Document doc = null;
try {
doc = Jsoup.connect("http://moisilonesti.licee.edu.ro/concursuri.php").get();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Elements sElem = doc.select("div#olimpiade table tbody tr th");
String str = sElem.text();
TextView stv = (TextView) findViewById(R.id.textView2);
stv.setText(str);}}
LogCat トレースは次のとおりです。
11-17 17:37:59.145: E/AndroidRuntime(23601): FATAL EXCEPTION: main
11-17 17:37:59.145: E/AndroidRuntime(23601): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.ex.myschoolapp/com.ex.myschoolapp.MainActivity}: java.lang.NullPointerException
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1659)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1675)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.ActivityThread.access$1500(ActivityThread.java:121)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:943)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.os.Handler.dispatchMessage(Handler.java:99)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.os.Looper.loop(Looper.java:123)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.ActivityThread.main(ActivityThread.java:3701)
11-17 17:37:59.145: E/AndroidRuntime(23601): at java.lang.reflect.Method.invokeNative(Native Method)
11-17 17:37:59.145: E/AndroidRuntime(23601): at java.lang.reflect.Method.invoke(Method.java:507)
11-17 17:37:59.145: E/AndroidRuntime(23601): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:862)
11-17 17:37:59.145: E/AndroidRuntime(23601): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
11-17 17:37:59.145: E/AndroidRuntime(23601): at dalvik.system.NativeStart.main(Native Method)
11-17 17:37:59.145: E/AndroidRuntime(23601): Caused by: java.lang.NullPointerException
11-17 17:37:59.145: E/AndroidRuntime(23601): at com.ex.myschoolapp.MainActivity.onCreate(MainActivity.java:67)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
11-17 17:37:59.145: E/AndroidRuntime(23601): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1623)
11-17 17:37:59.145: E/AndroidRuntime(23601): ... 11 more
AsyncTask の使用方法はまだわかりませんが、Jsoup クックブックで見たところ、機能させるためにスレッドは必要ありません。