5

私はこの質問を見つけましたが、多少同じ質問がありました。

XLSX - デフォルトの名前空間プレフィックス x: を取り除く方法は?

OpenXML Excel ワークシートを生成するときに問題が発生しました。特にスタイルシート部分。

スタイル シートが何らかの形でタイムラインのスタイルを取得すると (Excel 2013 のみ)、Excel ファイルを生成できます。スタイル シートには、適切な名前空間 ( xmlns:x="...") が含まれます。これにより、Excel 2010 で開くことができます。ただし、生成された Excel ファイルを Excel 2010 で保存すると、x 名前空間が既定の名前空間になり、タイムライン拡張要素を除くすべての要素から削除されます。Excel でファイルを再度開くと、エラーが発生します。OpenXml Productivity Tool で同じファイルを開くと、x が不明な名前空間であるというエラーが表示されます。

したがって、ここにいくつかのxml-resultコードがあります。

まず、Excel ファイル (stylesheet.xml) を生成した後:

<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<x:styleSheet xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" xmlns:x15="http://schemas.microsoft.com/office/spreadsheetml/2010/11/main" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:x14ac="http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac" xmlns:x="http://schemas.openxmlformats.org/spreadsheetml/2006/main" mc:Ignorable="x14ac">
  <x:fonts count="3" x14ac:knownFonts="1">
    <x:font>
      <x:sz val="11"/>
      <x:color theme="1"/>
      <x:name val="Calibri"/>
      <x:family val="2"/>
      <x:scheme val="minor"/>
    </x:font>
    <!-- more fonts -->
  </x:fonts>
  <x:fills count="7">
    <x:fill>
      <x:patternFill patternType="none"/>
    </x:fill>
    <!-- more fills -->
  </x:fills>
  <x:borders count="1">
    <x:border>
      <x:left/>
      <x:right/>
      <x:top/>
      <x:bottom/>
      <x:diagonal/>
    </x:border>
  </x:borders>
  <x:cellStyleXfs count="1">
    <x:xf numFmtId="0" fontId="0" fillId="0" borderId="0"/>
  </x:cellStyleXfs>
  <x:cellXfs count="18">
    <x:xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0"/>
    <x:xf numFmtId="14" fontId="0" fillId="0" borderId="0" xfId="0" applyNumberFormat="1"/>
    <x:xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" applyNumberFormat="1"/>
    <x:xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" pivotButton="1"/>
    <x:xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" applyAlignment="1">
      <x:alignment horizontal="left"/>
    </x:xf>
    <!-- more cells -->
  </x:cellXfs>
  <x:cellStyles count="1">
    <x:cellStyle name="Standaard" xfId="0" builtinId="0"/>
  </x:cellStyles>
  <x:dxfs count="1">
    <x:dxf>
      <x:numFmt numFmtId="19" formatCode="m/d/yyyy"/>
    </x:dxf>
  </x:dxfs>
  <x:tableStyles count="0" defaultTableStyle="TableStyleMedium2" defaultPivotStyle="PivotStyleLight16"/>
  <x:extLst>
    <x:ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{EB79DEF2-80B8-43e5-95BD-54CBDDF9020C}">
      <x14:slicerStyles defaultSlicerStyle="SlicerStyleLight1"/>
    </x:ext>
    <x:ext xmlns:x15="http://schemas.microsoft.com/office/spreadsheetml/2010/11/main" uri="{9260A510-F301-46a8-8635-F512D64BE5F5}">
      <x15:timelineStyles defaultTimelineStyle="TimeSlicerStyleLight1"/>
    </x:ext>
  </x:extLst>
</x:styleSheet>

そしてExcel 2010に保存した後

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<styleSheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:x14ac="http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac" mc:Ignorable="x14ac">
  <fonts count="3" x14ac:knownFonts="1">
    <font>
      <sz val="11"/>
      <color theme="1"/>
      <name val="Calibri"/>
      <family val="2"/>
      <scheme val="minor"/>
    </font>
    <!-- more fonts -->
  <fills count="7">
    <fill>
      <patternFill patternType="none"/>
    </fill>
    <!-- more fills -->
  </fills>
  <borders count="1">
    <border>
      <left/>
      <right/>
      <top/>
      <bottom/>
      <diagonal/>
    </border>
  </borders>
  <cellStyleXfs count="1">
    <xf numFmtId="0" fontId="0" fillId="0" borderId="0"/>
  </cellStyleXfs>
  <cellXfs count="18">
    <xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0"/>
    <xf numFmtId="14" fontId="0" fillId="0" borderId="0" xfId="0" applyNumberFormat="1"/>
    <xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" applyNumberFormat="1"/>
    <xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" pivotButton="1"/>
    <xf numFmtId="0" fontId="0" fillId="0" borderId="0" xfId="0" applyAlignment="1">
      <alignment horizontal="left"/>
    </xf>
    <!-- more cells -->
  </cellXfs>
  <cellStyles count="1">
    <cellStyle name="Standaard" xfId="0" builtinId="0"/>
  </cellStyles>
  <dxfs count="1">
    <dxf>
      <numFmt numFmtId="164" formatCode="m/d/yyyy"/>
    </dxf>
  </dxfs>
  <tableStyles count="0" defaultTableStyle="TableStyleMedium2" defaultPivotStyle="PivotStyleLight16"/>
  <extLst>
    <ext uri="{EB79DEF2-80B8-43e5-95BD-54CBDDF9020C}" xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main">
      <x14:slicerStyles defaultSlicerStyle="SlicerStyleLight1"/>
    </ext>
    <x:ext uri="{9260A510-F301-46a8-8635-F512D64BE5F5}" xmlns:x15="http://schemas.microsoft.com/office/spreadsheetml/2010/11/main">
      <x15:timelineStyles defaultTimelineStyle="TimeSlicerStyleLight1"/>
    </x:ext>
  </extLst>
</styleSheet>

ご覧のように。パーツには、他の<x:ext uri="{9260A510-F301-46a8-8635-F512D64BE5F5}"要素から削除された x 名前空間がまだ含まれています。

誰でもこれを修正する方法を知っていますか? x:私が最初に考えたのは、x 名前空間をデフォルトの名前空間にして、スタイル シートで をまったく必要としないようにすることです。しかし、openXML SDK にそうするように指示する方法を見つけることができませんでした。

4

1 に答える 1

3

I know this is an old question but just in case anyone else has the same issue, what I did is to remove the conflicting sections. Although is not the optimal solution, It allows the user to open the file in Excel 2010, re save it with another name and then re open the file just created without problems.

To remove the sections I used this code:

        if (Document.WorkbookPart.WorkbookStylesPart.Stylesheet.Descendants<StylesheetExtensionList>().Any())
        {
            Document.WorkbookPart.WorkbookStylesPart.Stylesheet.RemoveAllChildren<StylesheetExtensionList>();
        }

I din't use Document.WorkbookPart.WorkbookStylesPart.Stylesheet.Save() since I saved the changes in another place, but you might need to save it, it depends on your needs.

I opted to remove all the children, but maybe you can delete only the one that is causing the issue.

Hope this help you ;)

于 2014-02-05T20:23:49.280 に答える