Электронная таблица OpenXML, созданная в .NET, не открывается на iPad

Я пытаюсь создать электронную таблицу в .NET, которую мой менеджер будет открывать на своем iPad, когда его нет в офисе.

Электронная таблица отлично открывается на ПК с Windows, но при попытке открыть ее на iPad появляется сообщение «Произошла ошибка при чтении документа» (очень полезно!)

С помощью функции «Сравнить» в OpenXML SDK Инструмент повышения производительности с документом, который действительнооткрывается на iPad, и, вручную отредактировав XML-файлы неисправного документа в блокноте, я сузил его до файла xl/_rels/workbook.xml. .rels, в котором хранятся отношения частей в рабочей книге.

Это код, который я использую для создания WorkbookPart и ссылок.

    WorkbookPart workbookPart1 = document.AddWorkbookPart();

    WorkbookStylesPart workbookStylesPart1 = workbookPart1.AddNewPart<WorkbookStylesPart>("rId3");
    ThemePart themePart1 = workbookPart1.AddNewPart<ThemePart>("rId2");
    WorksheetPart worksheetPart1 = workbookPart1.AddNewPart<WorksheetPart>("rId1");

Мой код генерирует следующий вывод, который не открывается на iPad.

      <?xml version="1.0" encoding="utf-8" ?> 
      <Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships">
          <Relationship Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="/xl/styles.xml" Id="rId3" /> 
          <Relationship Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="/xl/theme/theme.xml" Id="rId2" /> 
          <Relationship Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet" Target="/xl/worksheets/sheet.xml" Id="rId1" /> 
      </Relationships>

Если я изменю значение атрибутов Target, чтобы использовать относительный ссылочный путь, что даст следующий вывод, то он откроется на iPad.

      <?xml version="1.0" encoding="utf-8" ?> 
      <Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships">
          <Relationship Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml" Id="rId3" /> 
          <Relationship Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme.xml" Id="rId2" /> 
          <Relationship Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet" Target="worksheets/sheet.xml" Id="rId1" /> 
      </Relationships>

Итак, вопрос:
Как изменить код .NET, чтобы он выдавал вторую версию XML с относительными путями.

С благодарностью приму любую помощь!

6
задан Jen 7 June 2012 в 09:23
поделиться