Table as html extracted from Excel range presents different layout in the presence of hidden columns

Hello,
we use Aspose Cells version 24.12 to extract as HTML a range from an Excel file.
The layout of the table, showed into the browser, changes if into the sheet where is present the range there is at least an hide column.

We would like to understand why the layout of the table changes if there are hidden columns into the sheet.

This is the original Excel layout: original-excel-layout.png
This is the layout of the table extracted from IDS-2577-FROM-SCRATCH.xlsx: expected-layout.png
This is the layout of the table extracted from IDS-2577-FROM-SCRATCH-WITH-COLUMNS-HIDE.xlsx: bad-layout.png

We attached a zip file that contains all files that can help you to replicate the scenario:

  • IDS-2577-FROM-SCRATCH.xlsx → original Excel file without hide columns
  • IDS-2577-FROM-SCRATCH-WITH-COLUMNS-HIDE.xlsx → copy of original Excel file where we have hidden the columns B and C
  • areaAsHtml.html → table as html extracted from the original file
  • areaAsHtmlWithColumnsHide.html → table as html extracted from the copied file
  • TestExtractHtmlFromRange.java → code using to extract the html from Excel file

Many thanks.
Regards,
Giulio

IDS-2577.zip (143.7 KB)

@giulio.andolfi

The issue you’re experiencing with the layout of the HTML table changing when hidden columns are present is likely related to how Aspose.Cells handles merged cells in conjunction with hidden rows or columns. When a range contains merged cells that span into hidden areas, it can lead to discrepancies in the resulting HTML output, causing some cells to appear misaligned or offset from their intended positions.

This behavior has been observed in previous versions of Aspose.Cells, where the presence of hidden rows or columns resulted in uneven HTML tables. It appears that the library may not correctly account for the hidden elements when generating the HTML, leading to the layout issues you are seeing.

To address this, you might want to consider the following steps:

  1. Check for Merged Cells: Ensure that your range does not include merged cells that extend into hidden columns. If they do, it may be necessary to adjust your range or the way you handle merged cells.

  2. Update Aspose.Cells: If you are using an older version of Aspose.Cells, consider updating to the latest version, as there may have been fixes or improvements related to this issue.

  3. Use Export Options: When exporting to HTML, you can specify options that control how hidden rows and columns are treated. For example, you can set the HiddenColDisplayType and HiddenRowDisplayType to remove or adjust how hidden elements are represented in the output.

If the problem persists, it may be beneficial to report this behavior to Aspose support, as they can provide more specific guidance or investigate further.

For more detailed information on handling such scenarios, you can refer to discussions on similar issues in the Aspose community, where users have shared their experiences and solutions.

If you have any further questions or need assistance with specific code examples, feel free to ask!

@giulio.andolfi,

Thanks for the sample Excel files, screenshots and code segment.

Let us evaluate your issue using your sample files and code snippet. We will get back to you soon.

Thank you @amjad.sahi for your support.
Let me know as soon as possible, please.
Regards,
Giulio

@giulio.andolfi,

I have tested your scenario/case using your sample Excel files and code snippet. Please try to replace the lines of code:

options.setHiddenRowDisplayType(HtmlHiddenRowDisplayType.REMOVE);
options.setHiddenColDisplayType(HtmlHiddenColDisplayType.REMOVE); 

with:

options.setHiddenRowDisplayType(HtmlHiddenRowDisplayType.HIDDEN);
options.setHiddenColDisplayType(HtmlHiddenColDisplayType.HIDDEN);

and it will work for the purpose.

Let us know if you still find any issue.

Hello @amjad.sahi,
unfortunately we cannot changes the “HiddenRowDisplayType” and “HiddenColDisplayType” because if we use HIDDEN instead of REMOVE when the hidden rows or columns are inside the range, the “insertHtml” does not hidden them.

Into the file “IDS-2577-FROM-SCRATCH-WITH-COLUMN-HIDE-INSIDE-THE-RANGE.xlsx” we have hidden the column H and I.

Using the test “getAreaAsHtmlWithColumnsHidden” presents into the class “TestExtractHtmlFromRange”, we extracted the html and we saved it into the file “IDS-2577-table-col-hidden.html”

Using the test “insertTableHtmlWithColHidden” presents into the class “TestInsertTable” we read the html and inserted it into a Word Document “TestInsertTable.docx”.

Into the file “insert-table-html-with-col-hidden.docx” you can see the result: the column H and I are visible.

Analyzed the html we saw that the columns are hidden using java script and we presume that the “documentBuilder.insertHtml(html);” is not compatible with java script. The same problem occurs when we try to insert the html using the Word.js API.

Could you help us to understand if there is another method to insert the html without layout problems?
Many thanks,
Giulio

FOR-ASPOSE.zip (47.4 KB)

@giulio.andolfi,

Thanks for sharing your scenario and concerns with sample files.

We are sorry that the suggested lines of code won’t work for your scenario. We need to evaluate your issue thoroughly. We will check if it is an issue with the APIs or there can be some other way around to cope with it in code. 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-46213

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.

Hello @amjad.sahi,
Please let me know when there are news.
Thanks

@giulio.andolfi,

We haven’t resolved your issue yet. We will share new updates as soon as they are available.

@giulio.andolfi ,

Your issue has been fixed now. The fix will be included in the release (Aspose.Cells v25.2) that we plan to release in the first half of February 2025. You will be notified when the next version is released.
Here is the result after fix for your reference:
output.zip (4.4 KB)

Hello @Eric.wang,
many thanks for the notice.
We will update the Aspose cells version to 25.2 as soon as it will be released and we will test the scenario again.
The results that you have attached are correct.
Regards

@giulio.andolfi
Thank you for your feedback. You are welcome. We will notify you promptly once the version v25.2 is released.