我正在尝试创建一个 2007+ Excel 文档 (.xlsx),只使用.net 4.0 built-in classes。所以我不能使用任何第三方库。
实际上它已经完成了大部分,我现在面临的唯一问题是,我正在创建的包似乎在创建[Content_Types].xml文件时失败,我的意思是它缺少所有<Override>元素,并且只创建<Default>元素。
我很确定问题出在我创建包之间的关系的地方,但我只是不知道如何使它工作,而且Package和ZipPackage类的文档和示例非常稀缺。
也许我错过了另一个步骤......有人有任何线索吗?请
这是一个类似的代码,它产生完全相同的问题
public void CreatePackage()
{
string Dir = @"F:\Proyectos\Excel_StackOverflow\WindowsFormsApplication1\WindowsFormsApplication1\Resources";
Uri File1_abs = new Uri(String.Format(@"{0}\1.xml", Dir), UriKind.Absolute);
Uri File1_rel = new Uri(@"/OddContent/File1.xml", UriKind.Relative);
using (ZipPackage exPkg = (ZipPackage)Package.Open(String.Format(@"{0}\Temp.zip", Dir), FileMode.Create))
{
ZipPackagePart File1Part = (ZipPackagePart)exPkg.CreatePart(File1_rel, System.Net.Mime.MediaTypeNames.Text.Xml);
using (FileStream fs1 = new FileStream(File1_abs.LocalPath, FileMode.Open, FileAccess.Read))
{
Form1.CopyStream(fs1, File1Part.GetStream());
}
exPkg.CreateRelationship(File1_rel, TargetMode.Internal, "SomeType");
exPkg.Flush();
exPkg.Close();
}
}
private static void CopyStream(Stream source, Stream target)
{
const int bufSize = 0x1000;
byte[] buf = new byte[bufSize];
int bytesRead = 0;
while ((bytesRead = source.Read(buf, 0, bufSize)) > 0)
target.Write(buf, 0, bytesRead);
}
它为给定代码生成的 [Content_Types].xml 文件是:
<?xml version="1.0" encoding="UTF-8"?>
<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types">
<Default ContentType="text/xml" Extension="xml"/>
</Types>
但实际上我希望这样的内容是 [Content_Types].xml 文件内容:
<?xml version="1.0" encoding="UTF-8"?>
<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types">
<Default ContentType="text/xml" Extension="xml"/>
<Override PartName="...................."/>
</Types>