15

Sto provando a leggere in un file di testo di un gruppo di parole che voglio utilizzare per un gioco di parole che sto scrivendo. Questo elenco è memorizzato nella directory delle risorse ed è un file txt. Ma, ogni volta che tento di aprirlo, lancia un'eccezione.Lettura del file dalla directory delle risorse genera FileNotFoundException

List<String>wordList = new ArrayList<String>(); 
    BufferedReader br = null; 
    try { 
     br = new BufferedReader(new InputStreamReader(getAssets().open("wordlist.txt"))); //throwing a FileNotFoundException? 
     String word; 
     while((word=br.readLine()) != null) 
     wordList.add(word); //break txt file into different words, add to wordList 
    } 
     catch(IOException e) { 
      e.printStackTrace(); 
     } 
     finally { 
      try { 
       br.close(); //stop reading 
      } 
      catch(IOException ex) { 
       ex.printStackTrace(); 
      } 
     } 
     String[]words = new String[wordList.size()]; 
     wordList.toArray(words); //make array of wordList 

     for(int i=0;i<words.length; i++) 
      Log.i("Brian", words[i]); //print out words in array 
} 

Ecco il log degli errori, nel caso in cui questo è di alcun aiuto:

02-22 20:49:47.646: WARN/System.err(2351): java.io.FileNotFoundException: wordlist.txt 
02-22 20:49:47.646: WARN/System.err(2351):  at android.content.res.AssetManager.openAsset(Native Method) 
02-22 20:49:47.746: WARN/System.err(2351):  at android.content.res.AssetManager.open(AssetManager.java:299) 
02-22 20:49:47.746: WARN/System.err(2351):  at android.content.res.AssetManager.open(AssetManager.java:273) 
02-22 20:49:47.756: WARN/System.err(2351):  at com.bic.anagram.GameActivity.onCreate(GameActivity.java:40) 
02-22 20:49:47.756: WARN/System.err(2351):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
02-22 20:49:47.756: WARN/System.err(2351):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2521) 
02-22 20:49:47.756: WARN/System.err(2351):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2574) 
02-22 20:49:47.766: WARN/System.err(2351):  at android.app.ActivityThread.access$2400(ActivityThread.java:121) 
02-22 20:49:47.766: WARN/System.err(2351):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1925) 
02-22 20:49:47.766: WARN/System.err(2351):  at android.os.Handler.dispatchMessage(Handler.java:99) 
02-22 20:49:47.776: WARN/System.err(2351):  at android.os.Looper.loop(Looper.java:136) 
02-22 20:49:47.776: WARN/System.err(2351):  at android.app.ActivityThread.main(ActivityThread.java:4425) 
02-22 20:49:47.776: WARN/System.err(2351):  at java.lang.reflect.Method.invokeNative(Native Method) 
02-22 20:49:47.776: WARN/System.err(2351):  at java.lang.reflect.Method.invoke(Method.java:521) 
02-22 20:49:47.776: WARN/System.err(2351):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
02-22 20:49:47.776: WARN/System.err(2351):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
02-22 20:49:47.776: WARN/System.err(2351):  at dalvik.system.NativeStart.main(Native Method) 
02-22 20:49:47.776: WARN/dalvikvm(2351): threadid=3: thread exiting with uncaught exception (group=0x4001e280) 

Grazie a tutti!

risposta

19

Verificare se il file è stato correttamente inserito nella cartella delle risorse all'interno del file .apk. (Può essere sfogliati come file zip. Rinominarlo se necessario, per guardare dentro.)

+0

È interessante notare che il file era lì quando ho fatto un export da Eclipse, ma quando ho tirato il file fuori il mio telefono (da dati/app), l'intera directory beni era MIA. Come faccio a creare questa directory? –

+17

Trovato! Ho dovuto fare clic con il tasto destro del mouse sulla cartella delle risorse in Eclipse, quindi scegliere Crea percorso -> Usa come cartella di origine. Ora Eclipse lo costruisce quando impacchetta l'apk. È stato un buon suggerimento Grazie! –

+0

In realtà, ho fatto sì che il "grande commento" segnasse solo un po 'di rapidità ... Se avessi contrassegnato le "risorse" come una cartella di origine, non funzionava: il file non è stato trovato. Se lo lascio semplicemente (standard), ha funzionato correttamente =) – Ted

Problemi correlati