博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
asp.net 读取导入的project(mpp)文件
阅读量:5330 次
发布时间:2019-06-14

本文共 2137 字,大约阅读时间需要 7 分钟。

公司项目有用到读取project文件(.mpp)并保存到指定数据库类似的功能。

查了一下大家总结的方法。

找到一哥们代码,初步判断可行,特此收藏。

using System.IO; using Microsoft.Office.Interop.MSProject;

需要引入Microsoft.Office.Interop.MSProject组件

引入方式见:http://blog.csdn.net/Flyear_cheng/archive/2008/09/07/2895865.aspx

参考:http://blog.csdn.net/wenzhixing/archive/2008/09/11/2911461.aspx

 

Microsoft.Office.Interop.MSProject.ApplicationClass prj = new ApplicationClass();

 

            string prjFileName = Server.MapPath("../upfile/计划.mpp");

             //Response.Write(prjFileName);

            //if (new FileInfo(prjFileName).Exists)

            //    Response.Write("文件存在");

            //else

            //    Response.Write("文件不存在");

 

            prj.FileOpen(prjFileName, true, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Microsoft.Office.Interop.MSProject.PjPoolOpen.pjPoolReadOnly, Type.Missing, Type.Missing, Type.Missing, Type.Missing);

        

            foreach (Microsoft.Office.Interop.MSProject.Project proj in prj.Projects)

            {

                Response.Write("<table border=1 width=100%>");

                Response.Write("<tr><td>任务编号</td><td>任务名</td><td>优先级</td><td>开始时间</td><td>结束时间</td><td>资源名</td><td>WBS号</td><td>完成百分比</td><td>是否完成</td><td>摘要</td><td>前置任务</td></tr>");

                foreach (Microsoft.Office.Interop.MSProject.Task task in proj.Tasks)

                {

                    if (task != null)

                    {

                        int iTaskLevel = task.OutlineLevel;

                        string str = string.Empty;

                        for (int j = 0; j < iTaskLevel; j++)

                        {

                            str += "---";

                        }

                      

 

                        Response.Write("<tr><td>"+task .ID+"</td><td>" + str + task.Name + "</td><td>"+task .Priority+"</td><td>" + task.Start + "</td><td>" + task.Finish + "</td><td>" + task.ResourceNames.ToString() + "</td><td>" + task.WBS + "</td><td>" + task.PercentComplete + "</td><td>" + task.ActualFinish + "</td><td>"+task.Notes +"</td><td>");

                        foreach (Task t in task.PredecessorTasks)

                            Response.Write(t.WBS+":"+t.Name);

                        Response.Write("</td></tr>");

                    }

                  

                }

            }

 

以上引自:http://www.cnblogs.com/ringwang/archive/2009/05/20/1471585.html

 

注:如果VS报错 无法嵌入互操作类型“Microsoft.Office.Interop.MSProject.ApplicationClass”。请改用适用的接口。

在Visual Studio 中点击菜单项“视图->解决方案资源管理器”,在其中点开“引用”文件夹,在"Microsoft.Office.Interop.MSProject" 上点击鼠标右键,选择“属性”,将属性中的“嵌入互操作类型”的值改为“false”即可

转载于:https://www.cnblogs.com/WMwanglei/p/4362540.html

你可能感兴趣的文章
Shiro权限控制框架
查看>>
vsftpd虚拟用户【公司系统部分享】
查看>>
盒子box在网页中居中的方法
查看>>
Python之旅Day14 JQuery部分
查看>>
core--线程池
查看>>
redux-effect
查看>>
Swift和OC混编
查看>>
Android轻量级的开源缓存框架ASimpleCache
查看>>
他山之石:加载图片的一个小问题
查看>>
shell - 常识
查看>>
[PHP] excel 的导入导出
查看>>
SDL(01-10)
查看>>
IM开发通信协议基础知识(一)---TCP、UDP、HTTP、SOCKET
查看>>
mssql sqlserver 使用sql脚本 清空所有数据库表数据的方法分享
查看>>
分层图最短路【bzoj2763】: [JLOI2011]飞行路线
查看>>
FastReport.Net使用:[18]形状(Shape)控件用法
查看>>
linux下编译复数类型引发的错误:expected unqualified-id before '(' token
查看>>
codeforces 1041A Heist
查看>>
字典常用方法
查看>>
Spring Cloud Stream消费失败后的处理策略(三):使用DLQ队列(RabbitMQ)
查看>>