Я пытаюсь создать электронную таблицу в .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 с относительными путями.
С благодарностью приму любую помощь!