工程管理mpp导入导出解决方案

本文介绍了如何使用C#处理MSProject文件,实现甘特图的导入和导出。通过Microsoft.Office.Interop.MSProject库,实现了从.MPP文件中读取任务信息并填充到DataTable,以及将数据写入新的.MPP文件。同时,提供了选择文件、导入到数据库和导出文件的按钮操作。
摘要由CSDN通过智能技术生成

   前不久,刚实习,遇到的项目是工程类的,其中要实现的功能是甘特图的导入和导出。到网上找了很久,没有好的解决方案,就自己做了一个。

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using Microsoft.Office.Interop.MSProject;
using System.IO;
using com.jwsoft.pm.data;
using Microsoft.Office;

public partial  class projectImport : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    /// <summary>
    /// 导入数据
    /// </summary>
    /// <param name="fileName"></param>
    private void GetIMP(string fileName)
    {
        DataTable dt = new DataTable();
        dt.Columns.Add("选择", Type.GetType("System.Boolean"));
        dt.Columns.Add("wbs", Type.GetType("System.String"));
        dt.Columns.Add("taskcode", Type.GetType("System.String"));
        dt.Columns.Add("任务名称", Type.GetType("System.String"));
        //dt.Columns.Add("优先级", Type.GetType("System.String"));task.Priority,
        dt.Columns.Add("开始时间", Type.GetType("System.DateTime"));
        dt.Columns.Add("结束时间", Type.GetType("System.DateTime"));
        dt.Columns.Add("完成百分比", Type.GetType("System.String"));
        //dt.Columns.Add("是否完成", Type.GetType("System.String"));task.ActualFinish,
        dt.Columns.Add("前置任务", Type.GetType("System.String"));
        dt.Columns.Add("孩子个数", Type.GetType("System.Int32"));
        dt.Columns.Add("父节点", Type.GetType("System.String"));
        try
        {
            Microsoft.Office.Interop.MSProject.ApplicationClass prj = new ApplicationClass();
            string filename = fileName;
            prj.FileOpen(filename, true, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值