Jira数据导出,Java写mpp文件

原创 2014年12月25日 17:16:29

   关键字: Jira和MsProject互导/java写MsProject文件/java写Mpp文件/nileader/ni掌柜

        1.       JIRA上读取数据。

2.       读写MSProject文件。

 

JIRA上读取数据,主要有两种方法:

方法一 采用HTTPClient的方法来抓取页面数据(JIRA3.*.*的建议采用这种方法),

         具体实现过程中,首先必须让JIRA站点能够允许匿名查看项目的问题.

         另外不要知道每个项目 版本对应的pidfixfor.

         使用httpclient访问的时候,使用这个路径比较好:

#获得所有Issue的页面

JIRA_ISSUE_FULLCONTENT={domain}/sr/jira.issueviews:searchrequest-fullcontent/temp/SearchRequest.html?pid={pid}&fixfor={fixfor}&resolution=-1&sorter/field=priority&sorter/order=DESC&tempMax=10000

 

      在这个页面中,可以一次性获取问题的issueKey, summarydesc.

   一般获取这个页面源代码之后,可以通过这些正则表达式:

 

  1. // 获取问题的issueKey <h3 class="formtitle">[SANDBOX-1]&nbsp; 
  2.     final static Pattern ISSUE_KEY_PATTERN = Pattern.compile( 
  3.             "<h3 class=\"formtitle\">(\\s)+\\[(?s).*?&", Pattern.CANON_EQ); 
  4.  
  5.     // 获得问题的Summary <a 
  6.     // href="http://jira.taobao.ali.com/browse/SANDBOX-1">TimeoutThread或Thread.setTimeout</a> 
  7.     final static Pattern ISSUE_SUMMARY_PATTERN = Pattern.compile( 
  8.             "<h3 class=\"formtitle\">(\\s)+\\[(?s).*?&nbsp;<a href=\"" 
  9.                     + JpContext.jiraDomain 
  10.                     + "/browse/(\\S)+(-)([0-9])+\">(?s).*?</a>"
  11.             Pattern.CANON_EQ); 
  12.  
  13.     // 获取问题的描述<div id="description_full">......</div> 
  14.     final static Pattern ISSUE_DESC_PATTERN = Pattern.compile( 
  15.             "<td id=\"descriptionArea\">(?s).*?</td>", Pattern.CANON_EQ); 
  16.  
  17.     // 获取问题的fixversion <b>修复版本:...........</tr> 
  18.     final static Pattern ISSUE_FIXVERSION_PATTERN = Pattern.compile( 
  19.             "<b>修复版本(?s).*?</tr>", Pattern.CANON_EQ); 

 获得issueKey之后,就可以进行子任务的获取了,具体获取方法,

  1. #获得指定issueKey的问题的所有子任务 
  2. JIRA_ISSUESUB_URL={domain}/browse/{issueKey} 

 方法二.通过JIRA提供的API进行相应问题的获取,这种途径只能在JIRA4.0.0及以上版本中可以使用.

 

 使用JIRA的soap客户端来获取jira站点上的所有问题的方法:

首先要实例出一个soap对象

  1. SOAPSession soapSession = new SOAPSession(new URL(baseUrl)); 
  2. soapSession.getJiraSoapService();

这个SOAPSession其实是帮我们封装了com.atlassian.jira.rpc.soap.service中的一些类。

获取所有的issue 

 

  1. SearchSoapExerciser se = new SearchSoapExerciser(soapSession); 
  2.  
  3.             // 存储所有问题 
  4.  
  5.             /** 遍历所有的issues */ 
  6.             try { 
  7.                 for (RemoteIssue ri : se.testJqlSearch(""10)) { 

遍历后就可以得到所有RemoteIssue对象了。

完整代码在附件中  

查看jira的api http://docs.atlassian.com/software/jira/docs/api/rpc-jira-plugin/

 接下去看看将问题下载到本地后,如何处理这些问题及其和子任务.

由于要将问题导入到msproject中进行管理,那么必然要进行java操作msproject文件的过程.

java操作msproject文件方面,已经有一个很好的开源包了,http://mpxj.sourceforge.net/index.html, 这个包唯一的不足之处是他能够读取msproject文件*.mpp中的内容,但是在写方面,他只能通过*.xml作为中间过渡.

     读mpp文件

  • net.sf.mpxj.mpp.MPPReader: reads Microsoft Project MPP files
  • net.sf.mpxj.mpx.MPXReader: reads Microsoft MPX files
  • net.sf.mpxj.mspdi.MSPDIReader: reads Microsoft MSPDI (XML) files
  • net.sf.mpxj.mpd.MPDIReader: reads Microsoft MPD files
  • net.sf.mpxj.planner.PlannerReader: reads Planner (XML) files

    写:

  • net.sf.mpxj.mpx.MPXWriter: writes Microsoft MPX files
  • net.sf.mpxj.mspdi.MSPDIWriter: writes Microsoft MSPDI (XML) files
  • net.sf.mpxj.planner.PlannerWriter: writes Planner (XML) files

 

 

一般的做法就是这样:

通过net.sf.mpxj.mpp.MPPReader: reads Microsoft Project MPP files来读取msproject文件内容

通过net.sf.mpxj.mspdi.MSPDIWriter: writes Microsoft MSPDI (XML) files生成一个msproject支持的文件,

 

  1. package com.test; 
  2.  
  3. import java.io.IOException; 
  4. import net.sf.mpxj.MPXJException; 
  5. import net.sf.mpxj.ProjectFile; 
  6. import net.sf.mpxj.mpp.MPPReader; 
  7. import net.sf.mpxj.mspdi.MSPDIWriter; 
  8. import net.sf.mpxj.reader.ProjectReader; 
  9. import net.sf.mpxj.writer.ProjectWriter; 
  10. public class Test{ 
  11.     public static void main(String[] args)throws Exception{ 
  12.         ProjectReader reader = new MPPReader(); 
  13.         ProjectFile project; 
  14.         try { 
  15.             project = reader.read("d:\\native.mpp"); 
  16.             //生成文件 
  17.             ProjectWriter writer = new MSPDIWriter(); 
  18.             try
  19.                 writer.write(project, "d:\\test.xml"); 
  20.             }catch(IOException ioe){ 
  21.                 throw ioe; 
  22.             } 
  23.         } catch (MPXJException mpxje) { 
  24.             throw mpxje; 
  25.         } catch (Exception e) { 
  26.             e.printStackTrace(); 
  27.         } 
  28.     } 

 

     这种做法的结果是:每次用project打开这个xml文件时候,都会进行一次导入向导:

每次导入的打开的时候.....

 

很显然,这样的做法用户体验相当差   这里推荐一种使用Java写mpp文件的做法

方法来源:

http://sourceforge.net/projects/jawinproject/

http://msdn.microsoft.com/en-us/library/bb244274(v=office.12).aspx

 

利用jawin可以进行windows的com组件调用, 利用Project Object Model Reference 可以生成一个msproject 支持的文件.  这样就可以通过Java写*.mpp文件了

具体做法如下:

  1. //实例一个app,这个app可以想象成是一个ms project的应用程序 
  2.             /**这里要指明的一点的是,使用这种方法生成*.mpp文件的前提是你的电脑上必须安装有msproject这个软件*/ 
  3.             app = new DispatchPtr("MSProject.Application"); 
  1. /**从这个链接中可以发现app有个成员是http://msdn.microsoft.com/en-us/library/bb236984(v=office.12).aspx*/ 
  2.             DispatchPtr projects = (DispatchPtr) app.get("Projects"); 

 

接下去,ms 官方给我们的提示是:

http://msdn.microsoft.com/en-us/library/bb214615(v=office.12).aspx

 

Use the Add method to add a Project object to the Projects collection. The following example creates a new project without prompting for project information. 

 由于实例出com组件的对象,通过jawin帮我们封装好的反射来

  1. /**从这个链接中可以发现http://msdn.microsoft.com/en-us/library/bb214615(v=office.12).aspx*/ 
  2.             DispatchPtr project = (DispatchPtr) projects.invoke("Add"); 

 接下去的事情好办了,有了一个project对象后,我们相当于只要调用project下面的方法来生成一个详细的project.

所谓详细的project就是为他添加多个task.

 

  1. //生成一个task集合 
  2. DispatchPtr tasks = (DispatchPtr) project.get("Tasks"); 
  3.  
  4. //之后多次调用来生成一个个任务 
  5. DispatchPtr taskName = (DispatchPtr) tasks.invoke("Add"); 
  6.  
  7. //当然要为任务设置属性:这要是name notes, 
  8. issueName.put("Name", issueKey + ":" + issueSummary ); 
  9. issueName.put("Notes", issueDesc ); 
  10. issueName.put("OutlineLevel""1"); 
  11. //在task对象中,没有明确的父子关系可以确定,在生成的过程中,都是更具生成的id和UniqueID顺序排下去的 
  12. //唯一可以确定最终在msproject中的结构的就是一个 
  13. OutLineLevel属性了. 

最后,进行保存操作,以及不要忘记进行应用程序的关闭.

  1. project.invoke("SaveAs", mppPath); 
  2. app.invoke("DocClose" ); 

 

 所有要用到的jar包:

http://down.51cto.com/data/123027

本文出自 “专栏:Paxos与ZooKeeper” 博客,请务必保留此出处http://nileader.blog.51cto.com/1381108/376597

Asp.net 甘特图数据导出Project(.mpp)文件

一、cs后台代码    1.1 主函数 private void ExportMpp(HttpContext context) { string ret =...
  • xuezt
  • xuezt
  • 2016年03月21日 09:45
  • 1705

java 导入读取.mpp project文件(甘特图)

写这个的思路是:将.mpp文件中的内容读取出来,我只需要他的一级和二级目录,一级目录、二级目录各一张表,二级目录表存一级目录的主键id,这点和网上其他的方法不太一样,大多数都是一张表就完事的,因为表不...
  • baidu_22244991
  • baidu_22244991
  • 2016年11月30日 16:09
  • 2025

Java利用mpxj解析mpp格式文件

MPXJ解析MPP文件, 同时获取每条子任务的父任务,并将子任务存储至数据库。
  • loongshawn
  • loongshawn
  • 2016年04月01日 16:44
  • 4318

java读写mpp文件的开源包

  • 2009年09月11日 09:14
  • 14.06MB
  • 下载

java读取mpp文件

  • 2015年04月09日 21:56
  • 22.51MB
  • 下载

java 读取 解析微软Project .mpp 文件到甘特图

1.引入价包; org.apache.poi poi 3.15 ...
  • qq_25385555
  • qq_25385555
  • 2017年03月24日 18:30
  • 272

解析mpp文件的jar包

  • 2013年08月06日 12:53
  • 2.29MB
  • 下载

2013年中国数据库大会-02-MPP NewSQL 数据库集群支撑企业超大规模数据仓库案例介绍

  • 2013年04月23日 21:49
  • 4.3MB
  • 下载

Microsoft Project的.mpp文件打开工具

  • 2011年11月10日 12:23
  • 24.21MB
  • 下载

非常好的mpp文件浏览软件

  • 2011年08月10日 08:32
  • 5.99MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Jira数据导出,Java写mpp文件
举报原因:
原因补充:

(最多只允许输入30个字)