Openxml 笔记
用openxml 生成Excel:
private void GenerateExcelUsingOpenxml(DataTable dataTable, string GeneratePath)
{
using (var workbook = SpreadsheetDocument.Create(GeneratePath, DocumentFormat.OpenXml.SpreadsheetDocumentType.Workbook))
{
var workbookPart = workbook.AddWorkbookPart();
workbook.WorkbookPart.Workbook = new DocumentFormat.OpenXml.Spreadsheet.Workbook();
workbook.WorkbookPart.Workbook.Sheets = new DocumentFormat.OpenXml.Spreadsheet.Sheets();
InitializeStyleSheet(workbookPart);
uint sheetId = 1;
var excelColumns = new DocumentFormat.OpenXml.Spreadsheet.Columns();
excelColumns.Append(CreateColumnData(1, Convert.ToUInt16(dataTable.Columns.Count + 1), 20));
var sheetPart = workbook.WorkbookPart.AddNewPart<WorksheetPart>();
var sheetData = new DocumentFormat.OpenXml.Spreadsheet.SheetData();
sheetPart.Worksheet = new DocumentFormat.OpenXml.Spreadsheet.Worksheet(excelColumns, sheetData);
DocumentFormat.OpenXml.Spreadsheet.Sheets sheets = workbook.WorkbookPart.Workbook.GetFirstChild<DocumentFormat.OpenXml.Spreadsheet.Sheets>();
string relationshipId = workbook.WorkbookPart.GetIdOfPart(sheetPart);
if (sheets.Elements<DocumentFormat.OpenXml.Spreadsheet.Sheet>().Count() > 0)
{
sheetId = sheets.Elements<DocumentFormat.OpenXml.Spreadsheet.Sheet>().Select(s => s.SheetId.Value).Max() + 1;
}
DocumentFormat.OpenXml.Spreadsheet.Sheet sheet = new DocumentFormat.OpenXml.Spreadsheet.Sheet() { Id = relationshipId, SheetId = sheetId, Name = sheetId.ToString() };
sheets.Append(sheet);
DocumentFormat.OpenXml.Spreadsheet.Row headerRow = new DocumentFormat.OpenXml.Spreadsheet.Row();
List<String> columns = new List<string>();
foreach (DataColumn column in dataTable.Columns)
{
columns.Add(column.ColumnName);
DocumentFormat.OpenXml.Spreadsheet.Cell cell = new DocumentFormat.OpenXml.Spreadsheet.Cell();
cell.DataType = DocumentFormat.OpenXml.Spreadsheet.CellValues.String;
cell.StyleIndex = 0U;
cell.CellValue = new DocumentFormat.OpenXml.Spreadsheet.CellValue(column.ColumnName);
headerRow.AppendChild(cell);
}
sheetData.AppendChild(headerRow);
foreach (DataRow dsrow in dataTable.Rows)
{
DocumentFormat.OpenXml.Spreadsheet.Row newRow = new DocumentFormat.OpenXml.Spreadsheet.Row();
foreach (String col in columns)
{
DocumentFormat.OpenXml.Spreadsheet.Cell cell = new DocumentFormat.OpenXml.Spreadsheet.Cell();
cell.DataType = DocumentFormat.OpenXml.Spreadsheet.CellValues.String;
cell.CellValue = new DocumentFormat.OpenXml.Spreadsheet.CellValue(dsrow[col].ToString()); //
cell.StyleIndex = 0U;
newRow.AppendChild(cell);
}
sheetData.AppendChild(newRow);
}
workbook.Close();
}
}
用Openxml 做mailmerge:
生成组合模板:public DataTable GenerateGroupTeamplates(DataTable DT)
{
//Add a dictinary type collection
Dictionary<string, int> TemplatePageCollection = new Dictionary<string, int> { };
IEnumerable<string> TemplateGroups = ConnectTemplateAndGroup_new(DT);
DataTable CustomerAndTempInfoDT = AddColumnForCustomerAndTempInfo(DT);
string MergedGroupTemplatesPath = SMConfig.MergedGroupTemplatePath;
string TemplateCopiedFolder =SMConfig.TempleFolderPath;
string SystemTemplatePath = SMConfig.TemplatePath;
DataTable TemplateCollection = GetTemplateInformation();
foreach (string TeamplateString in TemplateGroups)
{
int PageCount = 0;
string[] temps = TeamplateString.Split(',');
for (int i = 0; i < temps.Length; i++)
{
string OneTeampName = SystemTemplatePath + "\\" + TemplateCollection.Select("TemplateIndex='" + temps[i] + "'")[0]["TemplateName"].ToString();//Rows[indexRow]["TemplateName"].ToString();
File.Copy(OneTeampName, TemplateCopiedFolder + "\\" + temps[i]+ ".docx", true);
}
string ConnectFile = TemplateCopiedFolder + "\\" + temps[0] + ".docx";
for (int i = 1; i < temps.Length; i++)
{
string RecursiveFile = TemplateCopiedFolder + "\\" + temps[i] + ".docx";
using (WordprocessingDocument myDoc = WordprocessingDocument.Open(ConnectFile, true))
{
try
{
MainDocumentPart mainPart = myDoc.MainDocumentPart;
Paragraph SectionPageBreakParagraph = new Paragraph(new ParagraphProperties(new SectionProperties(new SectionType() { Val = SectionMarkValues.NextPage })));
Paragraph PageBreakParagraph = new Paragraph(new DocumentFormat.OpenXml.Wordprocessing.Run(new DocumentFormat.OpenXml.Wordprocessing.Break() { Type = BreakValues.Page }));
mainPart.Document.Body.Append(PageBreakParagraph);//此处添加空白页
mainPart.Document.Body.Append(SectionPageBreakParagraph);//add section breakparagraph
string altChunkId = "AltChunkId0" + i;
AlternativeFormatImportPart chunk = mainPart.AddAlternativeFormatImportPart(
AlternativeFormatImportPartType.WordprocessingML, altChunkId);
using (FileStream fileStream = File.Open(RecursiveFile, FileMode.Open))
{
chunk.FeedData(fileStream);
fileStream.Close();
}
AltChunk altChunk = new AltChunk();
altChunk.Id = altChunkId;
using (WordprocessingDocument tempFileDoc = WordprocessingDocument.Open(RecursiveFile, true))
{
PageCount = CountPage(PageCount, tempFileDoc);
IEnumerable<SectionProperties> sectionProperties = tempFileDoc.MainDocumentPart.Document.Body.Elements<SectionProperties>();
mainPart.Document.Body.InsertAfter(altChunk, mainPart.Document.Body.Elements<Paragraph>().Last());
mainPart.Document.Body.Last().Append(sectionProperties.FirstOrDefault().CloneNode(true));
mainPart.Document.Save();
myDoc.Close();
tempFileDoc.Close();
}
}
catch (Exception ex) { }
}
}
string GroupFilePath = MergedGroupTemplatesPath + "\\" + TeamplateString + ".docx";
File.Copy(ConnectFile, GroupFilePath, true);
string[] CopiedFiles = Directory.GetFiles(TemplateCopiedFolder);
for (int deleInd = 0; deleInd < CopiedFiles.Length; deleInd++)
{
File.Delete(CopiedFiles[deleInd]);
}
TemplatePageCollection.Add(new FileInfo(GroupFilePath).Name, PageCount+2);
}
//装载Page到DataTable
foreach (DataRow row in CustomerAndTempInfoDT.Rows)
{
row["Pages"] = TemplatePageCollection[row["GroupTemplateName"].ToString()];
}
return CustomerAndTempInfoDT;
}
Do Merge:
private void DoMerge(GeneratePara Param, string Path, string[] files)
{
for (int i = 0; i < files.Length; i++)
{
string uniqueFileName = string.Format("{0}Part{1}.docx", Path, i);
File.Copy(files[i], uniqueFileName, true);
DataRow[] drs = Param.SourceExcel.Select(String.Format("GroupTemplateName = '{0}'", new FileInfo(files[i]).Name));
CalculateSubPartPages.Add(string.Format("Part{0}.docx", i),Convert.ToInt32(drs[0]["Pages"])*(drs.Count()));
using (WordprocessingDocument wordDocument = WordprocessingDocument.Open(uniqueFileName, true), doc = WordprocessingDocument.Open(files[i], true))
{
XElement body = XElement.Parse(wordDocument.MainDocumentPart.Document.Body.OuterXml);
wordDocument.MainDocumentPart.Document.RemoveAllChildren();
wordDocument.MainDocumentPart.Document.AppendChild<Body>(new Body());
foreach (DataRow row in drs)
{
try
{
BindCalculateCustomerPart(i, row);
DataRow Row = Param.SourceData.Select("customer_no='" + row.ItemArray[0].ToString().PadLeft(9, '0') + "'")[0];
XElement newBody = XElement.Parse(doc.MainDocumentPart.Document.Body.OuterXml);
IList<XElement> mailMergeFields =
(from el in newBody.Descendants()
where ((el.Name == (XMLNS + "t") && el.Value != null && el.Value.Contains("«") && el.Value.Contains("»")))
select el).ToList();
string fieldName = string.Empty;
XElement newElement = null;
foreach (XElement field in mailMergeFields)
{
fieldName = field.Value.Replace("«", "").Replace("»", "").Replace("-", "_");
if (Row.Table.Columns.Contains(fieldName))
{
if (Row[fieldName] == DBNull.Value)
Row[fieldName] = string.Empty;
newElement = field;
newElement.Value = Regex.Replace(Row.Field<string>(fieldName).Trim(), "\\s+", " ", RegexOptions.IgnoreCase);
field.ReplaceWith(newElement);
}
}
Body bo = new Body(newBody.ToString());
wordDocument.MainDocumentPart.Document.Body.AppendChild<Body>(bo);
IEnumerable<SectionProperties> sectionProperties = doc.MainDocumentPart.Document.Body.Elements<SectionProperties>();
wordDocument.MainDocumentPart.Document.Body.Last().Append(sectionProperties.FirstOrDefault().CloneNode(true));
Paragraph PageBreakParagraph = new Paragraph(new ParagraphProperties(new SectionProperties(new SectionType() { Val = SectionMarkValues.EvenPage })));
wordDocument.MainDocumentPart.Document.Body.Append(PageBreakParagraph);//此处添加空白页
}
catch (Exception ex)
{
BindErrorCustomerNoDT(row.ItemArray[0].ToString());
continue;
}
}
wordDocument.MainDocumentPart.Document.Save();
wordDocument.Close();
}
}
}
Openxml 笔记的更多相关文章
- OpenXml SDK学习笔记(1):Word的基本结构
能写多少篇我就不确定了,可能就这一篇就太监了,也有可能会写不少. OpenXml SDK 相信很多人都不陌生,这个就是管Office一家的文档格式,Word, Excel, PowerPoint等都用 ...
- OpenXml SDK学习笔记(4):设置文件级别的样式
观察上一段日记最后的代码: 这里的样式基本可以理解为行内CSS.那么既然有行内的样式,就肯定有外部的样式.那这部分就对应笔记1里说的style.xml文件.这个文件对应的是Document.MainD ...
- VSTO 学习笔记(十)Office 2010 Ribbon开发
原文:VSTO 学习笔记(十)Office 2010 Ribbon开发 微软的Office系列办公套件从Office 2007开始首次引入了Ribbon导航菜单模式,其将一系列相关的功能集成在一个个R ...
- VSTO学习笔记(九)浅谈Excel内容比较
原文:VSTO学习笔记(九)浅谈Excel内容比较 说起文件内容比较,或许我们首先想到的是UltraCompare这类专业比较的软件,其功能非常强大,能够对基于文本的文件内容作出快速.准确的比较,有详 ...
- VSTO学习笔记(七)基于WPF的Excel分析、转换小程序
原文:VSTO学习笔记(七)基于WPF的Excel分析.转换小程序 近期因为工作的需要,要批量处理Excel文件,于是写了一个小程序,来提升工作效率. 小程序的功能是对Excel进行一些分析.验证,然 ...
- VSTO学习笔记(二)Excel对象模型
原文:VSTO学习笔记(二)Excel对象模型 上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升.从这次开始,将从VSTO 4.0开始,逐一探讨VSTO ...
- VSTO学习笔记(一)VSTO概述
原文:VSTO学习笔记(一)VSTO概述 接触VSTO纯属偶然,前段时间因为忙于一个项目,在客户端Excel中制作一个插件,从远程服务器端(SharePoint Excel Services)上下载E ...
- delphi操作xml学习笔记 之一 入门必读
Delphi 对XML的支持---TXMLDocument类 Delphi7 支持对XML文档的操作,可以通过TXMLDocument类来实现对XML文档的读写.可以利用TXMLDocum ...
- 【VS开发】VSTO 学习笔记(十)Office 2010 Ribbon开发
微软的Office系列办公套件从Office 2007开始首次引入了Ribbon导航菜单模式,其将一系列相关的功能集成在一个个Ribbon中,便于集中管理.操作.这种Ribbon是高度可定制的,用户可 ...
随机推荐
- Linux网络编程-IO复用技术
IO复用是Linux中的IO模型之一,IO复用就是进程预先告诉内核需要监视的IO条件,使得内核一旦发现进程指定的一个或多个IO条件就绪,就通过进程进程处理,从而不会在单个IO上阻塞了.Linux中,提 ...
- MyBatis源码分析-MyBatis初始化流程
MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以对配置和原生Map使用简 ...
- 新手!mass 设置问题
mass就是你那个物体的质量啊质量越大,惯性也越大重力也越大.假如你的刚体的mass为1,那么你只要给这个物体9.81N向上的力,你就可以抵消重力,让这个物体悬浮着:但假如这个物体的mass为10,你 ...
- linux下EOF写法梳理
在平时的运维工作中,我们经常会碰到这样一个场景:执行脚本的时候,需要往一个文件里自动输入N行内容.如果是少数的几行内容,还可以用echo追加方式,但如果是很多行,那么单纯用echo追加的方式就显得愚蠢 ...
- Centos7安装PHP7
安装依赖 yum updateyum install gcc-c++ libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel lib ...
- Hibernate 中出现表名(XXX) is not mapped 问题
今天晚上自己试着用Hibernate去搭建一个Web工程,然后去实现一个简单的登录.通过Hibernate?做查询操作的时候总是报出这样的错:users is?not?mapped. 于是乎去检查了下 ...
- [LeetCode] Reverse Integer 翻转整数
Reverse digits of an integer. Example1: x = 123, return 321 Example2: x = -123, return -321 click to ...
- 从点云到网格(三)Poisson重建
Possion重建是Kazhdan等2006年提出的网格重建方法[1].Possion重建的输入是点云及其法向量,输出是三维网格.Poisson有公开的源代码[2].PCL中也有Poisson的实现. ...
- Eclipse开发环境JDK版本问题和校验问题
今天遇到的两个问题: 1.启动程序报错:Unsupported major.minor version 52.0 这是JDK版本过低的问题,统一一下Build Path和java Complie中的版 ...
- MSSQLSERVER
create database test--创建数据库zh use test --打开数据库 go--执行 create table tab--创建表 ( UserName ),--创建字符串类型的字 ...