Queries about Aspose cells smart markers

Hi ,
We are facing following issues when working with smart markers.

  1. Dynamic formulas : When using a JSON data source with dynamic formulas in the template, the formula execution does not start from the current row as expected. Instead, it begins one row above the intended position resulting in #VALUE error. It always seems to start execution from row 1.
    Am I using the correct approach ? Please check the attachment

  2. When we place smart markers in middle of excel template even if data type is array it seems to print only single value and not the whole array ? Is it the expected behaviour or do the template needs some improvement ? example to refer in template “&=node.nestedArray.nestArr.some”

Aspose cells : 25.1 version

aspose_cells.zip (19.6 KB)

Looking forward to your feedback and guidance on resolving this issue.

@pgcentric

Can you please provide more details about the JSON data source you are using and the specific structure of your Excel template?

it is provided in the attachment .

@pgcentric,

Thanks for the template Excel file and JSON data file.

I tested using your JSON file a bit and found the first issue. To evaluate your both issues thoroughly, could you please share your sample (runnable) code that you are using on how you set your JSON data source and process the markers to get the resultant file. We will look into your issue(s) soon.

@Test
  void excel(){
    try {
      String data = "smart_marker.json";
      String fileName = "src/test/resources/input/excel/templates/smart_markers.xlsx";

      final WorkbookDesigner designer = new WorkbookDesigner();
      designer.setWorkbook(new Workbook(fileName));
      String jsonFile = testFileUtils.readJsonFile("input/excel/data", data);
      designer.setJsonDataSource("node", jsonFile);
      designer.process();
      designer
              .getWorkbook()
              .save("src/test/resources/input/excel/test-smart-marker-output.xlsx", SaveFormat.XLSX);
    } catch (Exception e) {
      throw new RuntimeException(e);
    }
  }

@pgcentric,

Thanks for the code snippet.

We need to evaluate your both issues in details. We have opened the following new ticket(s) in our internal issue tracking system and will deliver their fixes according to the terms mentioned in Free Support Policies.

Issue ID(s): CELLSJAVA-46248

You can obtain Paid Support Services if you need support on a priority basis, along with the direct access to our Paid Support management team.

Hi,
Also in JSON we have base64 image I hava placed

&=node.logo(Picture:FitToCell)

column O
In the template but generated document shows blank cells.

  1. Does version 25.1 supports base64 image bindings ?
  2. If yes what is the correct syntax ?
  3. If no are there any plans for base64 support ?

@pgcentric
CELLSJAVA46082.zip (7.0 KB)

Please check the template files and sample codes

Hi Thanks for quick response. It worked for single key ,and array of objects

We have few more questions

  1. Does this type of image binding is supported for array ?
"logos": [
    "",
    ""
   ]

It rendered blank cell
tried both
&=$node.logos(Picture:FitToCell)
&=node.logos(Picture:FitToCell)
2. Is it possible to use expression like &=if(&=node.active=true,1,0) inside formula ?
got error while generating document. is it expected behaviour ?

@pgcentric,

1). I tried to use your based64 image string in JSON file (attached) with the same template Excel file (provided by @simon.zhao in the zipped archive) and it works fine and as expected. I used the following sample code:
e.g.,
Sample code:

Workbook wb1 = new Workbook("d:\\files\\CELLSJAVA46082.xlsx");
WorkbookDesigner designer = new WorkbookDesigner();
designer.setWorkbook(wb1);
String jsonData = new String(Files.readAllBytes(Paths.get("d:\\files\\CELLSJAVA46082_new1.json")));
designer.setJsonDataSource("c8", jsonData);
designer.process();
wb1.save("d:\\files\\out1.xlsx");

Please find attached the new JSON file and output Excel file in the zipped archive for your reference.
files1.zip (14.7 KB)

Please try to update your JSON file and markers in your template file accordingly.

Yes the image bindngs works for simple key value pair my question was can you pass array of base64 strings for images

"logos": [
    "",
    ""
   ]

Like this here are two images in array. In my example this one did not work rest worked.
Also any feedback or suggestions on below question
2. Is it possible to use expression like &=if(&=node.active=true,1,0) inside formula ?
got error while generating document. is it expected behaviour ?

@pgcentric,

  1. Thanks for your feedback. We will look into base64 strings (images) and get back to you with updates.
  2. I’m sorry, but Smart Markers is a distinctive feature offered by Aspose.Cells that has its own syntax and style, which means you cannot always execute the task in the way you want. Smart Markers cannot be used directly within an if condition; however, you can utilize dynamic formulas in Smart Markers for this purpose, such as “&=&=IF(A{r}=…”, etc. You can insert markers like (“node.active”) in a A column and keep it hidden (if you want), and by using dynamic array formulas, you can apply your conditions by referencing the hidden column (marker) as needed.

@pgcentric,

1). For your information, currently Aspose.Cells does not support base64 image array data source for Smart Markers. We will evaluate it and support it. We have opened the following new ticket(s) in our internal issue tracking system and will deliver their fixes according to the terms mentioned in support policies.

  • Issue ID(s): CELLSJAVA-46250(old id: CELLSNET-57735)

You can obtain paid support services if you need support on a priority basis, along with the direct access to our Paid Support management team.

Hi ,

  1. when using “descending” parameter with JSON dataSource I have observed that it sorts all JSON dataSource and not just one specific array for example in above “&=$node.arrayNumber(noadd,descending:1)” . Is my approach correct ?
  2. Also could you please provide example of how “shift” and “horizontal” parameters can be used with above JSON data payload ? It didn’t work as per expectation when I tried it.

Looking forward to your feedback and guidance on resolving these issues.

@pgcentric,

Could you share examples along with sample Excel files to illustrate points 1) and 2) as proof of concept? We will assess and log relevant tickets to address any issues that may arise.

@pgcentric

Json data source does not support sorting ,shift, horizontal. And we have not plan to support them.

Thank you for the response.

@pgcentric
CELLSJAVA-46250.zip (26.3 KB)

Please check the attached template file and result file which is generated by inner hot fix 25.1.5

@pgcentric ,

The issues you have found earlier (filed as CELLSJAVA-46250) have been fixed in Aspose.Cells for Java 25.2.

In the example attached, we are facing an issue with rendering an array of objects. The ingredient_item has a languages array, but for index 0, it prints only a single value, whereas for the rest of the indices, it prints all values. Could you please take a look at it ?

array_of_objects_issue.zip (15.2 KB)

void excel(){
    try {
      String data = "sales_region_data.json";
      String fileName = "src/test/resources/input/excel/templates/template.xlsx";

      final WorkbookDesigner designer = new WorkbookDesigner();
      designer.setWorkbook(new Workbook(fileName));
      String jsonFile = testFileUtils.readJsonFile("input/excel/data", data);
      designer.setJsonDataSource("node", jsonFile);
      designer.process();
      designer
              .getWorkbook()
              .save("src/test/resources/input/excel/template_out.xlsx", SaveFormat.XLSX);
    } catch (Exception e) {
      throw new RuntimeException(e);
    }
  }