Предположим, у меня есть файл с содержимым JSON в папке сырых ресурсов в моем приложении. Как я могу прочитать это в приложении, чтобы разобрать JSON?
Ответы:
См. OpenRawResource . Примерно так должно работать:
InputStream is = getResources().openRawResource(R.raw.json_file);
Writer writer = new StringWriter();
char[] buffer = new char[1024];
try {
Reader reader = new BufferedReader(new InputStreamReader(is, "UTF-8"));
int n;
while ((n = reader.read(buffer)) != -1) {
writer.write(buffer, 0, n);
}
} finally {
is.close();
}
String jsonString = writer.toString();
\res\json_file.json
папки или внутри \res\raw\json_file.json
?
getResources()
позвонить? Куда должен идти файл сырых ресурсов? Какое соглашение вы должны соблюдать, чтобы гарантировать создание инструментов сборки R.raw.json_file
?
Kotlin теперь является официальным языком для Android, поэтому я думаю, что это будет полезно для кого-то
val text = resources.openRawResource(R.raw.your_text_file)
.bufferedReader().use { it.readText() }
Я использовал ответ @ kabuko для создания объекта, который загружается из файла JSON, используя Gson , из ресурсов:
package com.jingit.mobile.testsupport;
import java.io.*;
import android.content.res.Resources;
import android.util.Log;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
/**
* An object for reading from a JSON resource file and constructing an object from that resource file using Gson.
*/
public class JSONResourceReader {
// === [ Private Data Members ] ============================================
// Our JSON, in string form.
private String jsonString;
private static final String LOGTAG = JSONResourceReader.class.getSimpleName();
// === [ Public API ] ======================================================
/**
* Read from a resources file and create a {@link JSONResourceReader} object that will allow the creation of other
* objects from this resource.
*
* @param resources An application {@link Resources} object.
* @param id The id for the resource to load, typically held in the raw/ folder.
*/
public JSONResourceReader(Resources resources, int id) {
InputStream resourceReader = resources.openRawResource(id);
Writer writer = new StringWriter();
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(resourceReader, "UTF-8"));
String line = reader.readLine();
while (line != null) {
writer.write(line);
line = reader.readLine();
}
} catch (Exception e) {
Log.e(LOGTAG, "Unhandled exception while using JSONResourceReader", e);
} finally {
try {
resourceReader.close();
} catch (Exception e) {
Log.e(LOGTAG, "Unhandled exception while using JSONResourceReader", e);
}
}
jsonString = writer.toString();
}
/**
* Build an object from the specified JSON resource using Gson.
*
* @param type The type of the object to build.
*
* @return An object of type T, with member fields populated using Gson.
*/
public <T> T constructUsingGson(Class<T> type) {
Gson gson = new GsonBuilder().create();
return gson.fromJson(jsonString, type);
}
}
Чтобы использовать его, вы должны сделать что-то вроде следующего (пример находится в файле InstrumentationTestCase
):
@Override
public void setUp() {
// Load our JSON file.
JSONResourceReader reader = new JSONResourceReader(getInstrumentation().getContext().getResources(), R.raw.jsonfile);
MyJsonObject jsonObj = reader.constructUsingGson(MyJsonObject.class);
}
implementation 'com.google.code.gson:gson:2.8.5'
Из http://developer.android.com/guide/topics/resources/providing-resources.html :
сырые /
произвольные файлы для сохранения в необработанном виде. Чтобы открыть эти ресурсы с помощью необработанного InputStream, вызовите Resources.openRawResource () с идентификатором ресурса, которым является R.raw.filename.Однако, если вам нужен доступ к исходным именам файлов и иерархии файлов, вы можете подумать о сохранении некоторых ресурсов в каталоге assets / (вместо res / raw /). Файлы в assets / не имеют идентификатора ресурса, поэтому вы можете читать их только с помощью AssetManager.
Как и в @mah, в документации Android ( https://developer.android.com/guide/topics/resources/providing-resources.html ) говорится, что файлы json могут быть сохранены в каталоге / raw в каталоге / res (resources). каталог в вашем проекте, например:
MyProject/
src/
MyActivity.java
res/
drawable/
graphic.png
layout/
main.xml
info.xml
mipmap/
icon.png
values/
strings.xml
raw/
myjsonfile.json
Внутри Activity
json-файла можно получить доступ через R
класс (Resources) и прочитать его в String:
Context context = this;
Inputstream inputStream = context.getResources().openRawResource(R.raw.myjsonfile);
String jsonString = new Scanner(inputStream).useDelimiter("\\A").next();
При этом используется класс Java Scanner
, что приводит к меньшему количеству строк кода, чем некоторые другие методы чтения простого текстового / json-файла. Образец разделителя \A
означает «начало ввода». .next()
читает следующий токен, которым в данном случае является весь файл.
Есть несколько способов проанализировать полученную строку json:
optString(String name)
, и optInt(String name)
т.д. методы, а не getString(String name)
, getInt(String name)
методы, потому что opt
методы возвращают нуль вместо исключения в случае неудачи.import java.util.Scanner; import java.io.InputStream; import android.content.Context;
InputStream is = mContext.getResources().openRawResource(R.raw.json_regions);
int size = is.available();
byte[] buffer = new byte[size];
is.read(buffer);
is.close();
String json = new String(buffer, "UTF-8");
С помощью:
String json_string = readRawResource(R.raw.json)
Функции:
public String readRawResource(@RawRes int res) {
return readStream(context.getResources().openRawResource(res));
}
private String readStream(InputStream is) {
Scanner s = new Scanner(is).useDelimiter("\\A");
return s.hasNext() ? s.next() : "";
}
Нашел этот ответ на фрагмент Kotlin очень полезным ♥ ️
Хотя исходный вопрос был задан для получения строки JSON, я полагаю, что некоторые могут найти это полезным. Следующий шаг Gson
ведет к этой маленькой функции с овеществленным типом:
private inline fun <reified T> readRawJson(@RawRes rawResId: Int): T {
resources.openRawResource(rawResId).bufferedReader().use {
return gson.fromJson<T>(it, object: TypeToken<T>() {}.type)
}
}
Обратите внимание, что вы хотите использовать TypeToken
не просто T::class
так, если вы прочтете, List<YourType>
вы не потеряете тип за стиранием типа.
Затем вы можете использовать вывод типа следующим образом:
fun pricingData(): List<PricingData> = readRawJson(R.raw.mock_pricing_data)