import java.util.ArrayList;

import java.util.Calendar;

import java.util.Hashtable;

import java.util.List;

import net.sf.mpxj.ProjectFile;

import net.sf.mpxj.Relation;

import net.sf.mpxj.Task;

/**

* MSProject工具类

* @author
suhf

*

*/

publicclass MPPUtil {

static Hashtable<String,String>
dependencyTypes =
new Hashtable<String,String>();

publicstaticvoid init(){

dependencyTypes.put("FF",
"3");

dependencyTypes.put("FS",
"2");

dependencyTypes.put("SF",
"1");

dependencyTypes.put("SS",
"0");

}

/**

*
从MPP的Task读数据到数据库的BdTask

* @param task

* @param parentId

* @return

*/

privatestatic 
BdTask fetchTaskData(Task task, String parentId){

BdTask gttTask =new BdTask();

try{

gttTask.setPriority(1);

gttTask.setId(task.getUniqueID().toString());

gttTask.setNumbers(task.getID());

gttTask.setName(task.getName());

Double doub = Double.parseDouble(task.getDuration().toString().replaceAll("(?!\\.)[\\D]",
""));

gttTask.setDuration(doub.floatValue());

gttTask.setDurationUnit(task.getDuration().getUnits().toString());

Double effort = gttTask.getDuration()*8.0;

gttTask.setEffort(effort.intValue());

gttTask.setNote(task.getNotes());

gttTask.setPercentDone((task.getPercentageComplete().doubleValue()));

Calendar startDate = Calendar.getInstance();

Calendar endDate = Calendar.getInstance();

if(task.getMilestone()){//是里程碑

gttTask.setMilestone("1");

startDate.setTime(task.getStart());

//startDate.add(Calendar.DAY_OF_MONTH, 1);

endDate.setTime(task.getFinish());

//endDate.add(Calendar.DAY_OF_MONTH, 1);

}else{

gttTask.setMilestone("0");

startDate.setTime(task.getStart());

startDate.set(Calendar.HOUR_OF_DAY, 8);

startDate.set(Calendar.MINUTE, 30);

startDate.set(Calendar.SECOND, 0);

endDate.setTime(task.getFinish());

endDate.set(Calendar.HOUR_OF_DAY, 18);

endDate.set(Calendar.MINUTE, 0);

endDate.set(Calendar.SECOND, 0);

//endDate.add(Calendar.DAY_OF_MONTH, 1);

}

/*startDate.set(startDate.get(Calendar.YEAR),

startDate.get(Calendar.MONTH),

startDate.get(Calendar.DATE), 0, 0, 0);

endDate.set(endDate.get(Calendar.YEAR),

endDate.get(Calendar.MONTH),

endDate.get(Calendar.DATE), 0, 0, 0);*/

gttTask.setStartDate(DateFormatUtil.formatDateToString(startDate.getTime(), DateFormatUtil.V_LONG_DATE));

gttTask.setEndDate(DateFormatUtil.formatDateToString(endDate.getTime(), DateFormatUtil.V_LONG_DATE));

读取资源名称

/*List<ResourceAssignment> l = 
task.getResourceAssignments();

for (ResourceAssignment
ra : l) {

Resource r = ra.getResource();

if(r != null)

System.out.println(r.getName()+"--"+task.getName());

}*/

gttTask.setParentId(task.getParentTask().getUniqueID().toString()) ;

}catch(Exception e){

e.printStackTrace();

// System.exit(0);

}

return gttTask;

}

/**

*
获取项目计划任务数据

* @param projectFile MPP文件对象

* @return

* @throws Exception

*/

publicstatic List<BdTask> getTaskData(ProjectFile projectFile)
throws Exception{

List<BdTask> list =
new
ArrayList<BdTask>();

//这里有两层嵌套

for(Task tempTask :projectFile.getChildTasks())

{

int idx = 0;

for (Task task : tempTask.getChildTasks()) {

//加入最上层任务节点,
第三个參数parentId=0

BdTask gttTask =
fetchTaskData
(task,"");

//设置节点在姊妹节点下的顺序

gttTask.setIndexs(idx++);

//加入到数据库中

list.add(gttTask);

//递归调用

listHierarchy(task, list, gttTask.getId());

}

}

return list;

}

privatestatic List<BdTask> listHierarchy(Task task,List<BdTask> list, String parentId){

//节点的先后顺序

int idx = 0;

for (Task child : task.getChildTasks()) {

BdTask gttTask = fetchTaskData(child,parentId);

//设置任务的先后顺序

gttTask.setIndexs(idx++);

list.add(gttTask);

listHierarchy(child, list , parentId);

}

return list;

}

/**

*
获取项目计划任务关联数据

* @param projectFile MPP文件对象

* @return

* @throws Exception

*/

publicstatic List<BdDependency> getBdDependencyDate(ProjectFile projectFile){

List<BdDependency> list =
new
ArrayList<BdDependency>();

MPPUtil.init();//初始化MPP任务关联相应Gantt图的编号

//节点之间的关系

for (Task task : projectFile.getAllTasks()) {

List<Relation> predecessors = task.getPredecessors();

if (predecessors !=
null && predecessors.isEmpty() ==
false){

for (Relation relation : predecessors){

BdDependency dep =
new BdDependency();

dep.setToId(relation.getSourceTask().getUniqueID().toString());

dep.setFromId(relation.getTargetTask().getUniqueID().toString());

dep.setType(getDependencyType(relation.getType().toString()));

list.add(dep);

}

}

}

return list;

}

static String getDependencyType(String content){

Object ret = dependencyTypes.get(content);

return ret.toString();

}

}

使用mpxj读取MSPrjoect的更多相关文章

  1. ubuntu源码安装jdk8

    最近学习java,想起来没有在Ubuntu上使用过 因此想安装下环境,并在Ubuntu上试用MPXJ读取mpp文件 1.安装 下载jdk8 https://www.oracle.com/technet ...

  2. .NET读取Project 2007 MPP项目文件

    Project文件读取: 方法1:Microsoft.Project.OLEDB.11.0 string strConn = "Provider=Microsoft.Project.OLED ...

  3. nodejs进阶(4)—读取图片到页面

    我们先实现从指定路径读取图片然后输出到页面的功能. 先准备一张图片imgs/dog.jpg. file.js里面继续添加readImg方法,在这里注意读写的时候都需要声明'binary'.(file. ...

  4. 一步步开发自己的博客 .NET版(11、Web.config文件的读取和修改)

    Web.config的读取 对于Web.config的读取大家都很属性了.平时我们用得比较多的就是appSettings节点下配置.如: 我们对应的代码是: = ConfigurationManage ...

  5. Asp.Net MVC中使用StreamReader读取“Post body”之应用场景。

    场景:有三个市场(Global.China.USA),对前台传过来的数据有些验证需要细化到每个市场去完成. 所以就出现了基类(Global)和派生类(China.USA) 定义基类(Global)Pe ...

  6. HTML中上传与读取图片或文件(input file)----在路上(25)

    input file相关知识简例 在此介绍的input file相关知识为: 上传照片及文件,其中包括单次上传.批量上传.删除照片.增加照片.读取图片.对上传的图片或文件的判断,比如限制图片的张数.限 ...

  7. Win.ini和注册表的读取写入

    最近在做打包的工作,应用程序的配置信息可以放在注册表文件中,但是在以前的16位操作系统下,配置信息放在Win.ini文件中.下面介绍一下Win.ini文件的读写方法和注册表的编程. 先介绍下Win.i ...

  8. spring无法读取properties文件数据

    只讲述异常点,关于怎么配置文件,这里不做说明.   1. controller中无法读取config.properties文件 controller中注入的@Value配置是从servlet-cont ...

  9. 使用po模式读取豆瓣读书最受关注的书籍,取出标题、评分、评论、题材 按评分从小到大排序并输出到txt文件中

    #coding=utf-8from time import sleepimport unittestfrom selenium import webdriverfrom selenium.webdri ...

随机推荐

  1. 用宿主机创建一个容器bind命令的应用

    先创建一个网页目录 [root@docker ~]# mkdir /app/wwwroot -p 用bind运行,源目录为刚才创建的 [root@docker ~]# docker run -itd ...

  2. Android-ViewPagerIndicator框架使用——CirclePageIndicator

    前言:Circle适用于应用新功能的展示页和商品的多张图片的展示功能. 1.定义布局文件:SampleCirclesDefault中添加了一个布局:simple_circles. 布局中定义一个Lin ...

  3. 导出网页表格数据为Excel文件的前端解决方案

    在工作中,我们有时会遇到这样的需求,比如:要把页面的表格数据导出为Excel文件.在此记录下自己用的解决方法.代码如下: function tableToExcel(data){ //要导出的数据,t ...

  4. BZOJ 2406 LuoguP4194 矩阵 有上下界可行流

    分析: 这道题乍一看……卧槽这都什么玩意…… 然后发现给了个A矩阵,要求一个可行的B矩阵,使得矩阵C=A-B的每一行的和的绝对值和每一列的和的绝对值的最大值最小…… 好拗口啊…… 什么最大值最小之类的 ...

  5. json pickle shelve hashlib collections time

    import json # Json模块提供了四个功能:dumps.dump.loads.load dic = {'k1':'v1','k2':'v2','k3':'v3'} str_dic = js ...

  6. 集训第五周动态规划 H题 回文串统计

    Hrdv is interested in a string,especially the palindrome string.So he wants some palindrome string.A ...

  7. Jmeter&Ant构建自动化测试平台

    JMeter是一个软件,使负载测试或业绩为导向的业务(功能)测试不同的协议或技术. Apache软件基金会的Stefano Mazzocchi JMeter的最初的开发.他写道:它主要对 Apache ...

  8. 7-8 哈利·波特的考试(25 分)(图的最短路径Floyd算法)

    7-8 哈利·波特的考试(25 分) 哈利·波特要考试了,他需要你的帮助.这门课学的是用魔咒将一种动物变成另一种动物的本事.例如将猫变成老鼠的魔咒是haha,将老鼠变成鱼的魔咒是hehe等等.反方向变 ...

  9. SPOJ ARCTAN

    POJ1183 除输入方式外与这道题完全一样 题目大意是给定一个a 求最小的满足arctan(1/A)=arctan(1/B)+arctan(1/C) 的B+C的最小值 根据上述递推规律,我们只要从2 ...

  10. 【bzoj2152】聪聪可可 点分治

    [bzoj2152]聪聪可可 2014年9月7日3,5472 Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是 ...