《自拍教程59》Python 批量在浏览器里打开Jira Bug(附练手素材)

网友投稿 667 2022-09-21

《自拍教程59》Python 批量在浏览器里打开Jira Bug(附练手素材)

《自拍教程59》Python 批量在浏览器里打开Jira Bug(附练手素材)

准备阶段

Python的webbrowser 模块,可以轻松地实现打开网页url

openpyxl是首选的excel解析模块。

Python批处理脚本形式

记住批处理脚本的精髓:批量顺序执行语句

# coding=utf-8

import os

import webbrowser

import openpyxl

# 定义本模块(文件)内的常用变量

excel_file = "Witdrawn_Buglist.xlsx" # excel名称

bugid_col = 1 # Bug ID 列序号

url_prefix = "https://bugreports.qt.io/browse/" # jira url 前缀

# 获取BugID并在浏览器端打开

excel = openpyxl.load_workbook(excel_file) # 读取excel里边的内容

sheet = excel.active

rows = sheet.max_row

for r in range(2, rows + 1): # excel第一行是标题,需要过滤掉

bug_id = sheet.cell(row=r, column=bugid_col).value

webbrowser.open_new_tab("%s%s" % (url_prefix, bug_id)) # 在新窗口打开Jira Bug

os.system("pause")

Python面向过程函数形式

面向过程函数的编程思维应该是这样的:

你需要多少个功能(函数),才能做成这个事。

最好把功能(函数)都尽量封装好,只暴露一些的参数接口即可。

本次代码优化:

考虑到本次bug较多,188条,如果一次性在浏览器端打开,则会导致浏览器崩溃,

或者不容易查看, 所以需要考虑在Python程序执行中,每次只打开10条bug,

然后暂停,再然后按下任意键可继续显示另外的10条bug。

# coding=utf-8

import os

import webbrowser

import openpyxl

def open_url(url):

'''打开指定的url'''

webbrowser.open_new_tab(url)

def get_bug_id(excel_file, col_num):

bug_id_list = []

excel = openpyxl.load_workbook(excel_file) # 读取excel里边的内容

sheet = excel.active

rows = sheet.max_row

for r in range(2, rows + 1): # excel第一行是标题,需要过滤掉

bug_id = sheet.cell(row=r, column=col_num).value

bug_id_list.append(bug_id)

return bug_id_list

count = 0

bug_id_list = get_bug_id("Witdrawn_Buglist.xlsx", 1)

for i in bug_id_list:

open_url("https://bugreports.qt.io/browse/%s" % i)

# 如果能整除10,则暂停一次

count = count + 1

if count % 10 == 0:

os.system("pause")

os.system("pause") # 用于防止脚本运行后直接关闭导致看不到任何执行结果

Python面向对象类形式

面向对象类的编程思维应该是这样的:

如果给你一个空白的世界,在这个世界里你需要哪些种类的事物,

这些种类的事物都具备哪些共有的属性与方法,

这些种类(类)的事物(对象),和其他种类(其他类)的事物(其他对象)有什么关系。

尽量把这些类封装好,只暴露对外的属性(变量)和方法(函数)即可。

# coding=utf-8

import os

import webbrowser

import openpyxl

def open_url(url):

'''打开指定的url'''

webbrowser.open_new_tab(url)

class ExcelParser(object):

'''解析Excel,但是只定义一个函数获取bugID的即可'''

def __init__(self, excel_file):

self.__excel = openpyxl.load_workbook(excel_file) # 读取excel里边的内容, 无需被引用。

def get_bug_id(self, col_num):

bug_id_list = []

sheet = self.__excel.active

rows = sheet.max_row

for r in range(2, rows + 1): # excel第一行是标题,需要过滤掉

bug_id = sheet.cell(row=r, column=col_num).value

bug_id_list.append(bug_id)

return bug_id_list

if __name__ == '__main__':

count = 0

e_obj = ExcelParser("Witdrawn_Buglist.xlsx")

bug_id_list = e_obj.get_bug_id(1)

for i in bug_id_list:

open_url("https://bugreports.qt.io/browse/%s" % i)

# 如果能整除10,则暂停一次

count = count + 1

if count % 10 == 0:

os.system("pause")

os.system("pause") # 用于防止脚本运行后直接关闭导致看不到任何执行结果

运行方式

以上代码的3种实现形式都可以直接运行,比如保存为open_jira_bugs.py并放在桌面,

建议open_jira_bugs.py运行,当然也可以双击运行。

本案例练手素材-

跳转到官网-本练手素材

武散人出品,请放心-!

小提示:WithDrawn 的意思其实和Invalid, Rejected是类似的,表示被开发怼回来的,开发拒绝,不接受这类bug的意思,每个公司的Jira系统所设置的Bug状态稍有不同。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:day2-Samba
下一篇:UNIX/Linux 系统管理技术手册阅读(四)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~