Вложенная петля в отчете о рождении
Я использую Eclipse Birt для создания отчета из файла JSON.
Мой файл JSON выглядит так:
{
"cells":[
{
"type":"basic.Sensor",
"custom":{
"identifier":[
{
"name":"Name1",
"URI":"Value1"
},
{
"name":"Name4",
"URI":"Value4"
}
],
"classifier":[
{
"name":"Name2",
"URI":"Value2"
}
],
"output":[
{
"name":"Name3",
"URI":"Value3"
}
],
},
"image":{
"width":50,
"height":50,
"xlink:href":""
}
}
},
{
"type":"basic.Sensor",
"custom":{
"identifier":[
{
"name":"Name1",
"URI":"Value1"
},
{
"name":"Name4",
"URI":"Value4"
}
],
"classifier":[
{
"name":"Name2",
"URI":"Value2"
}
],
"output":[
{
"name":"Name3",
"URI":"Value3"
}
],
},
"image":{
"width":50,
"height":50,
"xlink:href":""
}
}
},
{
"type":"basic.Platform",
"custom":{
"identifier":[
{
"name":"Name1",
"URI":"Value1"
}
],
"classifier":[
{
"name":"Name2",
"URI":"Value2"
}
],
"output":[
{
"name":"Name3",
"URI":"Value3"
}
],
"image":{
"width":50,
"height":50,
"xlink:href":""
}
}
}
]
}
у меня есть 3 ячейки, и каждая из них содержит 1 изображение 1 имя 1 тип и 3 таблицы, это то, что я сделал до сих пор:
то, что я пытаюсь сделать, это вложенный цикл, я хочу иметь для каждого объекта (ячейки) в моем JSON абзац, который нумеруется следующим образом:
- 2.x Имя ячейки компонента:
- Образ
- Таблица вывода
- Таблица идентификаторов
- Таблица классификаторов
Поэтому, чтобы сделать это, мне нужно в каждой ячейке итерировать в каждой таблице. Выходные данные, идентификатор и классификатор, и я понятия не имею, как я могу это сделать, вложенный цикл. как список, который представляет количество ячеек, который содержит 3 таблицы, одно изображение, одно имя.
** Изменить: ** это открытый метод для набора данных
// Grab the JSON file and place it in a string
fisTargetFile = new FileInputStream(new File("C:/Users/Sample Reports/moe.json"));
input = IOUtils.toString(fisTargetFile, "UTF-8");
// Store the contents in a variable
jsonData = input;
// Convert the String to a JSON object
myJSONObject = eval( '(' + jsonData + ' )' );
// Get the length of the object
len = myJSONObject.cells.length;
// Counter
count = 0;
Метод выборки:
if(count < len) {
var name = myJSONObject.cells[count].attrs.text["text"];
var type = myJSONObject.cells[count].type;
var icon =myJSONObject.cells[count].attrs.image["xlink:href"];
icon = icon.split(",");
icon= icon[1];
imageDataBytes = icon;
row["name"] = name;
row["type"] = type;
row["icon"] = Base64ToBlob.toBytes(icon);
Logger.getAnonymousLogger().info( row["icon"]);
count++;
return true;
}
return false;
1 ответ
Если вы хотите использовать вложенные таблицы, есть хороший учебник, показывающий, как связать вложенные таблицы с внешней таблицей: пожалуйста, сначала внимательно посмотрите эту демонстрацию, в частности, посмотрите, как вложенная таблица связана с внешней таблицей через параметр набора данных.
Конечно, ваш случай более сложный, потому что вам нужно сделать это с помощью наборов данных со сценариями и нескольких вложенных таблиц. Я уже сделал что-то подобное, вы должны создать один набор сценариев для каждой вложенной таблицы. Ключевые моменты:
- В разделе "параметры" каждого поднабора данных создайте один входной параметр и назовите его, например, "systemID"
- Создайте свои вложенные таблицы, перетаскивая каждый набор данных во внешней таблице
- В разделе "Привязки" каждой вложенной таблицы свяжите параметр "systemID" с полем идентификатора внешней таблицы.
- В событии "open" поднаборов данных получите доступ к значению параметра с помощью этого выражения: inputParams ["systemID"] Таким образом, вы можете фильтровать связанные строки в " myJSONObject ".
- Важно убедиться, что myJSONObject инициализируется один раз для всех, иначе производительность может резко снизиться, если его оценивать на каждой итерации. Например, оцените это в событии "инициализировать" отчета.
Вот и все, это будет непросто, но эти элементы должны помочь в достижении этого отчета.