溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python如何統(tǒng)計(jì)Jira的bug并發(fā)送郵件功能

發(fā)布時(shí)間:2022-01-15 13:40:47 來(lái)源:億速云 閱讀:265 作者:柒染 欄目:開(kāi)發(fā)技術(shù)

本篇文章為大家展示了Python如何統(tǒng)計(jì)Jira的bug并發(fā)送郵件功能,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

Python如何統(tǒng)計(jì)Jira的bug并發(fā)送郵件功能

1.首先在pycharm上使用pip安裝

 pip install html-table
 pip install jira

2.初始化發(fā)件人郵箱,賬號(hào),密碼

# 發(fā)件人郵箱賬號(hào)
my_sender = 'username@xxx.com.cn'
# user登錄郵箱的用戶名,password登錄郵箱的密碼(授權(quán)碼,即客戶端密碼,非網(wǎng)頁(yè)版登錄密碼),但用騰訊郵箱的登錄密碼也能登錄成功
my_pass = 'xxxxx'
# 收件人郵箱賬號(hào)
my_users=['username@xxx.com.cn']

3.登錄Jira

class JiraTool:
#初始化
    def __init__(self):
        self.server = 'http://ip:5500' //連接Jira的Ip地址
        self.basic_auth = ('username', 'password') //連接Jira的賬戶和密碼
        self.jiraClinet = None

4.登錄Jira

def login(self):
    self.jiraClinet = JIRA(server=self.server, basic_auth=self.basic_auth)
    if self.jiraClinet != None:
        print("登錄成功!")
        return True
    else:
        return False

5.獲取Jira問(wèn)題列表

def get_issue_list_by_jql(self, jql):
    issue_list = []
    issue_key_list = self.jiraClinet.search_issues(jql_str=jql,startAt=0,maxResults=1000) //Jira默認(rèn)統(tǒng)計(jì)50條,maxResults設(shè)置大小
    for key_list in issue_key_list:
        issue = self.jiraClinet.issue(key_list.key)
        issue_list.append(issue)
        # print(issue.key) #關(guān)鍵字
        # print(issue.fields.summary) #bug描述
        # print(issue.fields.status) bug狀態(tài)
        # print(issue.fields.assignee) #經(jīng)辦人
        # print(issue.fields.components[0].name) #模塊 
        # print(issue.fields.priority) #優(yōu)先級(jí)
    return issue_list

6.創(chuàng)建一個(gè)表格

def gen_new_bug_caption_str(issue_list):
    dict = {}
    for issue in issue_list:
        dict[issue.fields.status.name] = dict.get(issue.fields.status.name, 0) + 1
        #dict[issue.key.split('-')[0]] = dict.get(issue.key.split('-')[0],0) + 1
    caption_str = '近一周共計(jì)新增bug' + str(len(issue_list)) + '個(gè)。 已關(guān)閉:' + str(dict.get('已關(guān)閉')) + '個(gè)。 已解決待關(guān)閉:' + str(dict.get('已解決')) + '個(gè)。 待處理:' +str(dict.get('待處理')) + '個(gè)'
    #print(caption_str)
    return caption_str

7.生成html

 #標(biāo)題樣式
    # table.caption.set_style({'font-size':'15px','align':'left'})
    table.caption.set_style({'font-size':'15px'})
    # 表格樣式,即<table>標(biāo)簽樣式
    table.set_style({
        'border-collapse':'collapse',
        'word-break':'keep-all',
        'white-space':'nowrap',
        'font-size':'14px'
    })
  
    #設(shè)置每個(gè)單元格的樣式,主要是規(guī)定邊框樣式:
    table.set_cell_style({
        'border-color':'#000',
        'border-width':'1px',
        'border-style':'solid',
        'padding':'5px',
    })
    #設(shè)置表頭單元格樣式,規(guī)定顏色,字體大小,以及填充大?。?
    #表頭樣式
    table.set_header_row_style({
        'color':'#fff',
        'background-color':'#696969',
        'font-size':'18px',
    })
    #覆蓋表單單元格字體樣式
    table.set_header_cell_style({
        'padding':'15px',
    })
    #遍歷數(shù)據(jù)行,根據(jù)不同狀態(tài)設(shè)置背景顏色
    for row in table.iter_data_rows():
        if row[1].value in "待處理":
            row[1].set_style({
                'background-color': '#FFB6C1',
            })
        if row[1].value in "已解決":
            row[1].set_style({
                'background-color': '#E1FFFF',
            })
        if row[1].value in "已關(guān)閉":
            row[1].set_style({
                'background-color': '#90EE99',
            })
        if row[1].value in "重新打開(kāi)":
            row[1].set_style({
                'background-color': '#DC143C',
            })
        if row[1].value in "開(kāi)發(fā)中":
            row[1].set_style({
                'background-color': '#f7d7a7',
            })
    #生成HTML文本:
    html = table.to_html()
    # print(html)
    return html

8.發(fā)送郵件

def sendmail(html):
    ret=True
    try:
        # 郵件內(nèi)容
        msg=MIMEText(html,'html','utf-8')
        # 括號(hào)里的對(duì)應(yīng)發(fā)件人郵箱昵稱、發(fā)件人郵箱賬號(hào)
        msg['From']=formataddr(["張三",my_sender])
        # 括號(hào)里的對(duì)應(yīng)收件人郵箱昵稱、收件人郵箱賬號(hào)
        #msg['To']=formataddr(["李四",my_user])
        # 郵件的主題
        msg['Subject']="bug情況統(tǒng)計(jì)"
        server=smtplib.SMTP_SSL("smtp.exmail.qq.com", 465)
        # 登錄服務(wù)器,括號(hào)中對(duì)應(yīng)的是發(fā)件人郵箱賬號(hào)、郵箱密碼
        server.login(my_sender, my_pass)
        # 發(fā)送郵件,括號(hào)中對(duì)應(yīng)的是發(fā)件人郵箱賬號(hào)、收件人郵箱賬號(hào)、發(fā)送郵件
        server.sendmail(my_sender, my_users, msg.as_string())
        # 關(guān)閉連接
        server.quit()
        # 如果 try 中的語(yǔ)句沒(méi)有執(zhí)行,則會(huì)執(zhí)行下面的 ret=False
    except Exception:
        ret=False
    return ret

9.調(diào)試

new_bug_jql = "project in (AAA, BBB, CCC)  AND issuetype in (Bug, 缺陷) AND created >= -1w ORDER BY component ASC, assignee ASC, priority DESC, updated DESC"
old_bug_jql = "project in (AAA, BBB, CCC)  AND issuetype in (Bug, 缺陷) AND status in (待處理, 開(kāi)發(fā)中, Reopened) AND created <= -1w ORDER BY component ASC, assignee ASC, priority DESC, updated DESC"
jiraTool = JiraTool()
jiraTool.login()
new_issue_list = jiraTool.get_issue_list_by_jql(new_bug_jql)
new_bug_caption_str = gen_new_bug_caption_str(new_issue_list)
new_bug_html = gen_html_table(new_issue_list,new_bug_caption_str)
# print(new_bug_html)
old_issue_list = jiraTool.get_issue_list_by_jql(old_bug_jql)
old_bug_html = gen_html_table(old_issue_list, "超過(guò)一周未關(guān)閉bug")
eamil_html = (new_bug_html + "<br/><br/><br/>" + old_bug_html).replace("&gt;", ">").replace("&quot;", "\"").replace("&lt;", "<")
# print(eamil_html)
ret=sendmail(eamil_html)
if ret:
    print("郵件發(fā)送成功")
else:
    print("郵件發(fā)送失敗")

上述內(nèi)容就是Python如何統(tǒng)計(jì)Jira的bug并發(fā)送郵件功能,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI