C#操作PPT表格
1.激活组件
AxFramerControl改控件的dll自己再网上百度下下载这里不多讲
/// <summary>
/// 检测是否注册控件
/// </summary>
public static void CheckDsoFramerExists()
{
string path = @"c:\windows\system32\dsoframer.ocx";
string filepath = Application.StartupPath;
if (!File.Exists(path))
{
File.Copy(filepath + "\\dsoframer.ocx", path);
}
ProcessStartInfo psi = new ProcessStartInfo("regsvr32", "/s " + path);
Process.Start(psi);
}
2.开始操作写入表格
里面包含创建单元格 单元格复制 单元格字体居中 合并单元格等操作
/// <summary>
/// 创建人员分布表
/// </summary>
/// <param name="obj"></param>
public static void CreateTempPersonInfoByCom(object obj)
{
PPT.Presentation ppt = obj as PPT.Presentation;
if (ppt == null) { return; }
//清楚ppt现有内容
int slides = ppt.Slides.Count;
for (int i = 0; i < slides; i++)
{
ppt.Slides[1].Delete(); ;
}
ppt.Slides.Add(1, PPT.PpSlideLayout.ppLayoutTable);
foreach (PPT.Slide item in ppt.Slides)
{
item.Shapes.Range(1).Delete();
item.Shapes.Range(1).Delete();
item.Shapes.AddTable(7, 9, 10, 10, 700, 300);
PPT.Table table = item.Shapes.Range(1).Table;
if (table != null)
{
table.Cell(1, 1).Shape.TextFrame.TextRange.Text = "类别";
table.Cell(1, 2).Shape.TextFrame.TextRange.Text = "数量";
table.Cell(1, 3).Shape.TextFrame.TextRange.Text = "独立操作人员数量";
table.Cell(1, 4).Shape.TextFrame.TextRange.Text = "工龄分布";
table.Cell(1, 8).Shape.TextFrame.TextRange.Text = "每日人员变动情况";
table.Cell(1, 9).Shape.TextFrame.TextRange.Text = "备注";
table.Cell(2, 4).Shape.TextFrame.TextRange.Text = "入职五年以上";
table.Cell(2, 5).Shape.TextFrame.TextRange.Text = "入职3-5年";
table.Cell(2, 6).Shape.TextFrame.TextRange.Text = "入职1-3年";
table.Cell(2, 7).Shape.TextFrame.TextRange.Text = "入职1年以下";
table.Cell(3, 1).Shape.TextFrame.TextRange.Text = "正式";
table.Cell(4, 1).Shape.TextFrame.TextRange.Text = "试用";
table.Cell(5, 1).Shape.TextFrame.TextRange.Text = "实习";
table.Cell(6, 1).Shape.TextFrame.TextRange.Text = "劳务";
table.Cell(7, 1).Shape.TextFrame.TextRange.Text = "合计";
//循环设置单元格样式
SetTableStyle(table);
//设置合并操作
table.Cell(1, 1).Merge(table.Cell(2, 1));
table.Cell(1, 2).Merge(table.Cell(2, 2));
table.Cell(1, 3).Merge(table.Cell(2, 3));
table.Cell(1, 8).Merge(table.Cell(2, 8));
table.Cell(1, 9).Merge(table.Cell(2, 9));
table.Cell(1, 4).Merge(table.Cell(1, 7));
}
}
}
//设置样式
/// <summary>
/// 设置table样式
/// </summary>
/// <param name="table"></param>
private static void SetTableStyle(PPT.Table table)
{
if (table == null) { return; }
//循环设置单元格样式
for (int i = 0; i < table.Rows.Count; i++)
{
for (int j = 0; j < table.Columns.Count; j++)
{
table.Cell(i + 1, j + 1).Shape.TextFrame.TextRange.Font.Size = 14;
table.Cell(i + 1, j + 1).Shape.TextFrame.HorizontalAnchor = MsoHorizontalAnchor.msoAnchorCenter;
table.Cell(i + 1, j + 1).Shape.TextFrame.VerticalAnchor = MsoVerticalAnchor.msoAnchorMiddle;
}
}
}
3.效果图如下

C#操作PPT表格的更多相关文章
- JAVA通过COM接口操作PPT
一. 背景说明 在Eclipse环境下,开发JAVA代码操作PPT,支持对PPT模板的修改.包括修改文本标签.图表.表格.满足大多数软件生成PPT报告的要求,即先收工创建好模板,在程序中修改模板数据. ...
- C++通过COM接口操作PPT
一. 背景 在VS环境下,开发C++代码操作PPT,支持对PPT模板的修改.包括修改文本标签.图表.表格.满足大多数软件生成PPT报告的要求,先手工创建好PPT模板,在程序中修改模板数据. 二. 开发 ...
- java poi 操作ppt
java poi 操作ppt 可以参考: https://www.w3cschool.cn/apache_poi_ppt/apache_poi_ppt_installation.html http:/ ...
- 黄聪:C#操作Word表格的常见操作(转)
几种常见C#操作Word表格操作有哪些呢?让我们来看看具体的实例演示: bool saveChange = false; //C#操作Word表格操作 object missing = System. ...
- c#操作word表格
http://www.webshu.net/jiaocheng/programme/ASPNET/200804/6499.html <% if request("infoid" ...
- qt 操作excel表格
自己编写的一个Qt C++类,用于操作excel表格,在Qt中操作excel需在.pro中增加CONFIG+=qaxcontainer配置. 1.打开Excel:objExcel = new QAx ...
- 转发:VB程序操作word表格(文字、图片)
很多人都知道,用vb操作excel的表格非常简单,但是偏偏项目中碰到了VB操作word表格的部分,google.baidu搜爆了,都没有找到我需要的东西.到是搜索到了很多问这个问题的记录.没办法,索性 ...
- Python 利用Python操作excel表格之openyxl介绍Part2
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart() ...
- Python 利用Python操作excel表格之openyxl介绍Part1
利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...
随机推荐
- (转)awk实例练习(二)
文章转自 http://www.cnblogs.com/zhuyp1015/archive/2012/07/14/2591842.html 先来总结一下awk内置变量: ARGC 命 ...
- PHP基础知识之————PHP Web脚本中使用FFmpeg
简介 本文将尝试指出在PHP Web脚本中使用FFmpeg时需要了解的所有重要事项.它还将显示一些使用示例,以使事情更清楚.这个想法也可以应用到其他web脚本语言. 从PHP脚本调用命令行工具 选择一 ...
- ajax提交表单+前端验证小示例
<script src="http://css.jj.cn/js/jquery.js" type="text/javascript"></sc ...
- mysql复制一列到另一列
mysql复制一列到另一列 UPDATE 表名 SET B列名=A列名 需求:把一个表某个字段内容复制到另一张表的某个字段. 实现sql语句1: 复制代码代码如下: UPDATE file_man ...
- ireport5.6+jasperreport6.3开发(五)--以javabean为基准的报表开发(action关联)
这里的是定方法主要参照sturts2-jasperreport-plugin的完成方法(其实就是抄的) PDF的样子是这样的两页的pdf 然后action的配置是这样的(不要在意格式) @Parent ...
- eclipse遇到不会部署的情况
1.先看下右下角有没有在进行的进程,例如validating 验证中.那就关闭验证的选项 2.看下problem栏有没有问题.会导致building不了.
- Attendance
1.打怪 福利好美味(色.... 努力是为了,遇到你时,可以不用因为种种而错过. 一公司的老板对一位职员说:“我出10万买你的老婆,你卖吗?” 职员微笑着说:“那我出15万买你老婆,你同意吗?” 老板 ...
- CSS3--overflow属性
overflow:当内容溢出元素框时发生的事情: overflow:默认,内容不会裁剪,会呈现在元素框之外: overflow:hidden:内容会被裁剪,并且其余部分是不可见的(清除浮动) over ...
- Unity脚本时间执行顺序
1.Awake Awake用于脚本唤醒.此方法为系统执行的第一个方法,用于脚本的初始化,在脚本的生命周期中只执行一次. 2.Start Start方法在Awake之后执行,在脚本生命周期中只执行一次. ...
- 使用CXF发布WebService
这里普及一下WebService和cxf的知识.关于webservice和cxf: WebService.各种提供服务的组件 .企业总线.通讯总线(ESB)CXF:是一个SOA框架,Axi ...