excel - 从/xl/worksheets/sheet1.xml部分coldfusion poi中删除记录合并单元格

标签 excel coldfusion apache-poi

我正在使用 java poi 库创建一个 excel 文件,它已创建,但是当我打开该文件时,excel 会弹出一条消息: “我们发现文件内容存在一些问题。您是否希望我们尽力恢复。如果您信任工作簿的来源。”

单击"is"时,会弹出“已修复部分:/xl/worksheets/sheet1.xml 部分,存在 XML 错误。加载错误。第 121 行,第 0 列。 删除的记录:合并/xl/worksheets/sheet1.xml 部分中的单元格”。

并且文件中没有数据丢失,我无法获取Excel错误背后的原因。

我无法在这里编写完整的代码,但这里是与 xlsx 文件相关的主要内容:

<cfdirectory action="list" directory="#expandPath('/poi_39')#" name="poidir"/>
            <cfset paths = arrayNew(1)>
            <cfloop query="poidir">
                <cfset arrayAppend(paths, directory & "\" & name) />
            </cfloop>
            <cfset server.loader = createObject("component", "javaloader.JavaLoader").init(loadPaths=paths, loadColdFusionClassPath=true) />
            <cfscript>
                _Thread = createObject("java", "java.lang.Thread");
                currentClassloader = _Thread.currentThread().getContextClassLoader();
                try {
                    // Set the current thread's context class loader as Javaloader's classloader, so dom4j doesn't die
                    _Thread.currentThread().setContextClassLoader(server.loader.getURLClassLoader());
                    //code found online
                    //inp = createObject("java", "java.io.FileOutputStream").init("#fullpath#");
                    //reseting the value on code
                    inp = 100;
                    //workBook = server.loader.create("org.apache.poi.xssf.usermodel.XSSFWorkbook").Init(inp);
                    workBook = server.loader.create("org.apache.poi.xssf.streaming.SXSSFWorkbook").Init(inp);
                }
                catch(Any exc) {
                    rethrow;
                }
                finally { // We have to reset the classloader, due to thread pooling.
                    _Thread.currentThread().setContextClassLoader(currentClassloader);
                }
            </cfscript>

            <!--- New code ends--->
            <cfset cellstyle = workbook.createCellStyle()>
            <cfset fontface = workbook.createFont()>
            <cfset fontface.setBoldweight(fontface.BOLDWEIGHT_BOLD)>
            <cfset cellstyle.setFont(fontface)>
            <cfset cellstyleData = workbook.createCellStyle()>
            <cfset format = workbook.createDataFormat() >
            <cfset cellintstyle = workbook.createCellStyle()>
            <cfset cellintstyle.setDataFormat(format.getFormat("0"))>
            <cfset cellfloatstyle = workbook.createCellStyle()>
            <cfset cellfloatstyle.setDataFormat(format.getFormat("0.0##"))>
            <cfset cellstyleData.setWrapText(true)/>

            <cfset cellstyleforallrows = workbook.createCellStyle()>
            <cfset fontfaceforallrows = workbook.createFont()>
            <cfset fontfaceforallrows.setColor(CreateObject( "java","org.apache.poi.hssf.util.HSSFColor$BLUE").getIndex())>
            <cfset cellstyleforallrows.setFont(fontfaceforallrows)>
            <cfset cellstyleforallrows.setWrapText(true)/>

                    <!--- creating new row object for the LEGEND title--->      
                    <cfset rowLegend = newSheetLegend.createRow(0)/>
                    <!--- Assigning the sheet name Legend--->
                    <cfset workBook.setSheetName(0, "LEGEND")/>
                    <!--- First Row First column text should be LEGEND. Giving that in bold --->
                    <cfset cellLegend = rowLegend.createCell(0)/> 
                    <cfset cellStyleStatic = createObject("java","org.apache.poi.xssf.usermodel.XSSFCellStyle")/>
                    <cfset cellLegend.setCellStyle(cellstyle)/>
                    <cfset cellLegend.setCellValue("LEGEND")/>
                    <cfset region = server.loader.create("org.apache.poi.ss.util.CellRangeAddress").init(0,0,0,48)/>
                    <cfset newSheetLegend.addMergedRegion(region)/>

在网络上也没有得到任何相关信息,有人遇到过这样的问题吗?如果是的话帮我解决这个问题。 谢谢

这是sheet1的mergecell xml的xml内容:

<x:mergeCells xmlns:x="http://schemas.openxmlformats.org/spreadsheetml/2006/main">
  <x:mergeCell ref="A1:AW1" />
  <x:mergeCell ref="B2:AW1" />
  <x:mergeCell ref="C3:AW1" />
  <x:mergeCell ref="D4:AW1" />
  <x:mergeCell ref="E5:AW1" />
  <x:mergeCell ref="F6:AW4" />
  <x:mergeCell ref="G7:C1" />
  <x:mergeCell ref="G7:AW4" />
  <x:mergeCell ref="H8:AW4" />
  <x:mergeCell ref="I9:AW4" />
  <x:mergeCell ref="J10:AW4" />
  <x:mergeCell ref="K11:AW4" />
  <x:mergeCell ref="L12:AW4" />
  <x:mergeCell ref="M13:AW4" />
  <x:mergeCell ref="N14:AW4" />
  <x:mergeCell ref="O15:AW4" />
  <x:mergeCell ref="P16:AW4" />
  <x:mergeCell ref="Q17:AW4" />
  <x:mergeCell ref="R18:AW4" />
  <x:mergeCell ref="S19:AW4" />
  <x:mergeCell ref="T20:AW4" />
  <x:mergeCell ref="U21:AW4" />
  <x:mergeCell ref="V22:AW4" />
  <x:mergeCell ref="W23:AW4" />
  <x:mergeCell ref="X24:AW4" />
  <x:mergeCell ref="Y25:AW4" />
  <x:mergeCell ref="Z26:AW4" />
  <x:mergeCell ref="AA27:AW4" />
  <x:mergeCell ref="AB28:AW4" />
  <x:mergeCell ref="AC29:AW4" />
  <x:mergeCell ref="AD30:AW4" />
  <x:mergeCell ref="AE31:AW4" />
  <x:mergeCell ref="AF32:AW4" />
  <x:mergeCell ref="AG33:AW4" />
  <x:mergeCell ref="AH34:AW4" />
  <x:mergeCell ref="AI35:AW4" />
  <x:mergeCell ref="AJ36:AW4" />
  <x:mergeCell ref="AK37:AW4" />
  <x:mergeCell ref="AL38:AW4" />
  <x:mergeCell ref="AM39:AW4" />
  <x:mergeCell ref="AN40:AW4" />
  <x:mergeCell ref="AO41:AW4" />
  <x:mergeCell ref="AP42:AW4" />
  <x:mergeCell ref="AQ43:AW4" />
  <x:mergeCell ref="AR44:AW4" />
  <x:mergeCell ref="AS45:AW4" />
  <x:mergeCell ref="AT46:AW4" />
  <x:mergeCell ref="AU47:AW4" />
  <x:mergeCell ref="AV48:AW4" />
  <x:mergeCell ref="AW49:AW4" />
  <x:mergeCell ref="AX50:AW4" />
  <x:mergeCell ref="AY51:AW4" />
  <x:mergeCell ref="AZ52:AW4" />
</x:mergeCells>

最佳答案

This thread表明较新的格式可能不太容忍重叠或重复。检查您的 CF 代码,看看它是否无意中创建了任何重复或冲突的区域。

在 POI 3.9 和 3.13 下,我能够通过将同一区域添加到电子表格两次或通过更新现有文件并添加已存在(或冲突)的区域来重现该错误与)电子表格中的现有区域。使用 zip 工具打开文件,并使用记事本检查 /xl/worksheets/sheet1.xml 文件,显示合并的单元格节点被添加了两次:

<mergeCells>
   <mergeCell ref="A1:AW1"/>
   <mergeCell ref="A1:AW1"/>
</mergeCells>

“修复”文件后,重复的节点被删除(当然错误也消失了):

<mergeCells>
   <mergeCell ref="A1:AW1"/>
</mergeCells>

再次检查任何添加区域的 CF 代码。如果您仍然不确定代码的哪一部分导致了问题,请尝试查看 /xl/worksheets/sheet1.xml 并搜索“mergeCells”。这应该会为您指明正确的方向。

更新:

查看sheet1.xml 中的合并单元格节点,看起来许多区域重叠,或者可能无效。例如,前两个区域均以 AW 列、1 行结束。 (由于第二个区域从第 2 行开始,我不确定终点是否有效?)

<x:mergeCell ref="A1:AW1" />
<x:mergeCell ref="B2:AW1" />

无论如何,调整范围以使它们不重叠(例如,如果第二个范围以 AW 列、第 2 行 结束)应该可以解决该错误。

<x:mergeCell ref="A1:AW1" />
<x:mergeCell ref="B2:AW2" />

关于excel - 从/xl/worksheets/sheet1.xml部分coldfusion poi中删除记录合并单元格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34944000/

相关文章:

excel - 如何在超过 60000 行的文本框中快速显示结果

ssl - 如何以及何时在 CFHTTP 标记中使用 ClientCert?

coldfusion - 将超过 100 个参数传递给 ColdFusion 函数会引发错误

java - 如何将excel中的数据存储到ArrayList<ArrayList<String>>

excel - 如何从列中的日期列表中找到最早的日期?

excel - 如何在 Excel 2007 中将多行折叠成一行?

excel - 如何向Excel列中的所有单元格添加常量?

coldfusion - 由于循环内 if 语句中函数调用内的结构文字而引发错误

java - 使用 apache poi 读取 .xlsx 文件在 linux 机器上给出 org.apache.poi.POIXMLException

java - 如何修复通过apache POI上传xlsx文件时的AbstractMethodError