Python操作Jira库常用方法解析


Posted in Python onApril 10, 2020

Jira提供了完善的RESTful API,如果不想直接请求API接口可以使用Python的Jira库来操作Jira

Jira Python文档

安装方法

pip install jira

认证

Jira的访问是有权限的,在访问Jira项目时首先要进行认证,Jira Python库提供了3种认证方式:

  • 通过Cookis方式认证(用户名,密码)
  • 通过Basic Auth方式认证(用户名,密码)
  • 通过OAuth方式认证

认证方式只需要选择一种即可,以下代码为使用Cookies方式认证。

form jira import JIRA

jira = JIRA('http://jira.***.com/', auth=('用户名', '登录密码')

返回的jira对象便可以对Jira进行操作。主要的操作包括:

  • 项目
  • 问题
  • 搜索
  • 关注者
  • 评论
  • 附件

项目(Project)

jira.projects(): 查看所有项目列表

jira.project("项目的Key"): 查看单个项目

项目对象的主要属性及方法如下:

  • key: 项目的Key
  • name: 项目名称
  • description: 项目描述
  • lead: 项目负责人
  • projectCategory: 项目分类
  • components: 项目组件
  • versions: 项目中的版本
  • raw: 项目的原始API数据

示例

print(jira.projects()) # 打印所有你有权限访问的项目列表

project = jira.project('某个项目的Key')

print(project.key, project.name, project.lead)

问题(Issue)

Issue是Jira的核心,Jira中的任务,用户Story,Bug实质上都是一个Issue。

单个问题对象可以通过jira.issue("问题的Key")得到,问题的主要属性和方法如下:

  • id: 问题的id
  • key: 问题的Key
  • permalink(): 获取问题连接
  • fields: 问题的描述,创建时间等所有的配置域
  • raw: 问题的原始API数据

配置域(Fields)

一般问题的ields中的属性分为固定属性和自定义属性,自定义属性格式一般为类似customfield_10012这种。常用的问题的Fields有:

  • assignee:经办人
  • created: 创建时间
  • creator: 创建人
  • labels: 标签
  • priorit: 优先级
  • progress:
  • project: 所示项目
  • reporter: 报告人
  • status: 状态
  • summary: 问题描述
  • worklog: 活动日志
  • updated: 更新时间
  • watches: 关注者
  • comments: 评论
  • resolution: 解决方案
  • subtasks: 子任务
  • issuelinks: 连接问题
  • lastViewed: 最近查看时间
  • attachment

示例如下:

issue = jira.issue('JRA-1330')
print(issue.key, issue.fields.summary, issue.fields.status)

关注者/评论/附件

  • jira.watchers(): 问题的关注者
  • jira.add_watcher(): 添加关注者
  • jira.remove_watcher(): 移除关注者
  • jira.comments(): 问题的所有评论
  • jira.comment(): 某条评论
  • jira.add_comment():添加评论
  • comment.update()/delete(): 更新/删除评论
  • jira.add_attachment(): 添加附件

示例如下:

issue = jira.issue('JRA-1330')

print(jiaa.watchers(issue)) # 所有关注者
jira.add_watcher(issue, 'username') # 添加关注者

print(jira.comments(issue)) # 所有评论
comment = jira.comment(issue, '10234') # 某条评论
jira.add_comment(issue, 'new comment') # 新增评论
comment.update(body='update comment') # 更新评论
comment.delete() # 删除该评论

print(issue.fields.attachment) # 问题附件
jira.add_attachment(issue=issue, attachment='/some/path/attachment.txt') # 添加附件

创建/分配/转换问题

  • jira.create_issue(): 创建问题
  • jira.create_issues(): 批量创建问题
  • jira.assign_issue(): 分配问题
  • jira.transitions(): 获取问题的工作流
  • jira.transition_issue(): 转换问题

示例如下:

# 创建问题
issue_dict = {
  'project': {'id': 123},
  'summary': 'New issue from jira-python',
  'description': 'Look into this one',
  'issuetype': {'name': 'Bug'},
}
new_issue = jira.create_issue(fields=issue_dict)

# 批量创建问题
issue_list = [
{
  'project': {'id': 123},
  'summary': 'First issue of many',
  'description': 'Look into this one',
  'issuetype': {'name': 'Bug'},
},
{
  'project': {'key': 'FOO'},
  'summary': 'Second issue',
  'description': 'Another one',
  'issuetype': {'name': 'Bug'},
},
{
  'project': {'name': 'Bar'},
  'summary': 'Last issue',
  'description': 'Final issue of batch.',
  'issuetype': {'name': 'Bug'},
}]
issues = jira.create_issues(field_list=issue_list)

# 分配问题
jira.assign_issue(issue, 'newassignee')

# 转换问题
jira.transition_issue(issue, '5', assignee={'name': 'pm_user'}, resolution={'id': '3'})

搜索

Jira的搜索非常强大,并配有一套专门的搜索语言,称为JQL(Jira Query Language),Jira的Python库便是基于JQL语法进行搜索的,返回的是搜索到的问题列表。
使用语句为

jira.search_issues('JQL语句')

默认最大结果数未1000,可以通过maxResults参数配置,该参数为-1时不限制数量,返回所有搜索结果。

jira.search_issues('project=PROJ and assignee = currentUser()', maxResults=-1)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
pydev使用wxpython找不到路径的解决方法
Feb 10 Python
python通过openpyxl生成Excel文件的方法
May 12 Python
详解python脚本自动生成需要文件实例代码
Feb 04 Python
python3+requests接口自动化session操作方法
Oct 13 Python
Python根据成绩分析系统浅析
Feb 11 Python
Django单元测试中Fixtures用法详解
Feb 25 Python
OpenCV Python实现拼图小游戏
Mar 23 Python
python库skimage给灰度图像染色的方法示例
Apr 27 Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
Jun 02 Python
Python 的 __str__ 和 __repr__ 方法对比
Sep 02 Python
Anaconda+spyder+pycharm的pytorch配置详解(GPU)
Oct 18 Python
一个入门级python爬虫教程详解
Jan 27 Python
jupyter notebook 使用过程中python莫名崩溃的原因及解决方式
Apr 10 #Python
jupyter lab的目录调整及设置默认浏览器为chrome的方法
Apr 10 #Python
jupyter notebook 参数传递给shell命令行实例
Apr 10 #Python
调整Jupyter notebook的启动目录操作
Apr 10 #Python
解决jupyter notebook显示不全出现框框或者乱码问题
Apr 09 #Python
jupyter 实现notebook中显示完整的行和列
Apr 09 #Python
jupyter notebook 多行输出实例
Apr 09 #Python
You might like
Laravel使用模型实现like模糊查询的例子
2019/10/24 PHP
JSONP 跨域访问代理API-yahooapis实现代码
2012/12/02 Javascript
jquery增加时编辑jqGrid(实例代码)
2013/11/08 Javascript
jQuery的ready方法详解
2014/11/27 Javascript
JavaScript控制listbox列表框的项目上下移动的方法
2015/03/18 Javascript
Angular中的interceptors拦截器
2017/06/25 Javascript
微信小程序实现tab和swiper切换结合效果
2020/07/17 Javascript
VueJs监听window.resize方法示例
2018/01/17 Javascript
JS中数组与对象的遍历方法实例小结
2018/08/14 Javascript
webpack-url-loader 解决项目中图片打包路径问题
2019/02/15 Javascript
node.js命令行教程图文详解
2019/05/27 Javascript
express框架下使用session的方法
2019/07/31 Javascript
js实现随机点名程序
2020/09/17 Javascript
element el-table表格的二次封装实现(附表格高度自适应)
2021/01/19 Javascript
[02:16]卖萌的僵尸 DOTA2神话信使飞僵小宝来袭
2014/03/24 DOTA
kNN算法python实现和简单数字识别的方法
2014/11/18 Python
python实现class对象转换成json/字典的方法
2016/03/11 Python
PYTHON压平嵌套列表的简单实现
2016/06/08 Python
python 将json数据提取转化为txt的方法
2018/10/26 Python
Python爬取数据保存为Json格式的代码示例
2019/04/09 Python
Python3获取cookie常用三种方案
2020/10/05 Python
css3高级选择器使用方法
2013/12/02 HTML / CSS
探索欧洲最好的品牌:Bombinate
2019/06/14 全球购物
The Outnet亚太地区:折扣设计师时装店
2019/12/05 全球购物
中级会计职业生涯规划范文
2014/01/16 职场文书
导师推荐信范文
2014/05/09 职场文书
企业理念标语
2014/06/09 职场文书
房屋出租委托书格式
2014/09/23 职场文书
铅球加油稿100字
2014/09/26 职场文书
居委会个人对照检查材料思想汇报
2014/09/29 职场文书
房地产公司财务总监岗位职责
2015/04/03 职场文书
中考百日冲刺决心书
2015/09/22 职场文书
如何在CocosCreator里画个炫酷的雷达图
2021/04/16 Javascript
Golang 获取文件md5校验的方法以及效率对比
2021/05/08 Golang
Go语言并发编程 sync.Once
2021/10/16 Golang
JavaScript实现一键复制内容剪贴板
2022/07/23 Javascript