Как упомянуто в комментарии @fabian - вы должны сначала проанализировать содержимое файла, изменить и перезаписать файл.Вот пример кода, как этого добиться:
Прежде всего, я не знаю, какую библиотеку json вы используете, но я настоятельно рекомендую использовать следующее:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.8</version>
</dependency>
Как правило, это облегчит вашу работу с JSON.Если вы не хотите использовать библиотеки, вы все равно можете следовать инструкции, но адаптировать ее под свои нужды.Вся реализация выглядит так:
public class JSONWriteExample {
private static final String FILE_NAME = "jsonArray.json";
private static final Path FILE_PATH = Paths.get(FILE_NAME);
private final String type;
private final int quantity;
public JSONWriteExample(String type, int quantity) {
this.type = type;
this.quantity = quantity;
}
public void jsonParse() throws IOException {
ObjectMapper objectMapper = new ObjectMapper();
if (Files.notExists(FILE_PATH)) {
Files.createFile(FILE_PATH);
objectMapper.writeValue(FILE_PATH.toFile(), createItems(new ArrayList<>()));
}
Items items = objectMapper.readValue(FILE_PATH.toFile(), Items.class);
final List<Item> itemsList = items.getItems();
objectMapper.writeValue(FILE_PATH.toFile(), createItems(itemsList));
}
private Items createItems(List<Item> itemsList) {
final Item item = new Item();
item.setType(type);
item.setQuantity(quantity);
itemsList.add(item);
final Items items = new Items();
items.setItems(itemsList);
return items;
}
public static class Items {
private List<Item> items;
// Setters, Getters
}
public static class Item {
private String type;
private int quantity;
// Setters, Getters
}
}
Хорошо, что происходит в этом коде?
- Прежде всего, обратите внимание на использование Java 7 NIO - рекомендуемый способ работыс файлами в java.
- В методе
jsonParse
мы сначала проверяем, существует ли файл. - Если это так - тогда мы читаем его в класс данных (
Items
), который описывает нашу модель.Часть для чтения выполняется изнутри этой библиотеки, только файлы вашего json-файла должны иметь те же имена, что и поля классов данных (или указаны с помощью JsonAlias
аннотации. - Если это не так)t - затем мы сначала создаем его и заполняем начальными значениями.
ObjectMapper
- это класс из библиотеки, и он используется для чтения \ записи файлов json.
Теперь, если мы запустим этот кусок кода, например,
public static void main(String[] args) throws IOException {
JSONWriteExample example = new JSONWriteExample("TV", 3);
example.jsonParse();
JSONWriteExample example2 = new JSONWriteExample("phone", 3);
example2.jsonParse();
}
json файл будет выглядеть так:
{
"items": [
{
"type": "TV",
"quantity": 3
},
{
"type": "TV",
"quantity": 3
},
{
"type": "phone",
"quantity": 3
}
]
}