使用python統(tǒng)計jira bug數(shù)據(jù)

一面睛、寫在前面

公司每天早晨站立會時絮蒿,都需要測試人員報告一下目前的bug情況,包括待辦叁鉴、測試中土涝、完成的數(shù)量,以及各個開發(fā)端:ios幌墓、android但壮、api....的情況。

于是測試人員每天早晨到公司后都需要做這樣的事:統(tǒng)計一下到今天早晨為止常侣,bug的情況蜡饵。這樣的事做一次還好,如果每天都做胳施,真是一件費時的事......

如果能寫一個程序溯祸,每天只需要運行一下程序,就能把想要的數(shù)據(jù)統(tǒng)計好舞肆,這樣會不會更好些呢焦辅?

這次要說的是使用python統(tǒng)計jira上的bug數(shù)據(jù)

二、程序運行結(jié)果

程序運行后出現(xiàn)了我想要的統(tǒng)計結(jié)果椿胯,如下圖所示筷登。

簡單介紹一下統(tǒng)計的內(nèi)容。內(nèi)容包括了項目的四個部分:ios(APP端)哩盲、android(APP端)前方、api(后端)、shuri(前端)廉油,其中30(0-0-15-15-0)镣丑,表示ios端有30個bug待辦,從左到右表示bug等級從Highest娱两、High莺匠、Medium、Low十兢、Lowest這五個等級對應(yīng)的bug的數(shù)量

bug統(tǒng)計結(jié)果

三趣竣、jira包下載

使用以下命令安裝jira包

pip install jira

四摇庙、JQL語句的使用

程序使用JQL對bug數(shù)據(jù)進行查詢和統(tǒng)計

看到這里,各位不要慌額遥缕。我弄這個的時候原本以為需要把JQL的相關(guān)語法從頭到尾的學習一遍呢卫袒,其實并不需要

jira中能將你的查詢用JQL表示出來,見下圖单匣,在圖中前面部分的查詢條件中填寫好你需要查詢的條件夕凝,然后點擊高級,就能將你的查詢的語句轉(zhuǎn)化為JQL語句

jira簡單查詢

下圖是jira中高級查詢的JQL語句户秤,是不是很棒呀

jira高級查詢

五码秉、編寫代碼

給出程序源碼

#coding=utf-8
from jira import JIRA

jira_server = 'http://jira.com'  #jira地址
jira_username = 'username' #用戶名
jira_password = 'password' #密碼

jira = JIRA(basic_auth=(jira_username, jira_password), options = {'server': jira_server})

#print(jira.user(jira.current_user()))#當前用戶

#
done = jira.search_issues('project = "test" AND issuetype = 故障 AND status = Done  ',maxResults=100000)

testing = jira.search_issues('project = "test" AND issuetype = 故障 AND status = 測試中  ',maxResults=100000)

toDo = jira.search_issues('project = "test" AND issuetype = 故障 AND status = "To Do"  ',maxResults=100000)


#ios

ios_done = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = Done AND text ~ "ios"  ',maxResults=100000)

ios_testing = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = 測試中 AND text ~ "ios"  ',maxResults=100000)

ios_toDo = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND text ~ "ios" ',maxResults=100000)

ios_Highest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Highest AND text ~ "ios" ',maxResults=100000)
ios_High = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = High AND text ~ "ios" ',maxResults=100000)
ios_Medium = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Medium AND text ~ "ios" ',maxResults=100000)
ios_Low = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Low AND text ~ "ios" ',maxResults=100000)
ios_Lowest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Lowest AND text ~ "ios" ',maxResults=100000)

#android

android_done = jira.search_issues('project = "test" AND issuetype = 故障 AND status = Done AND text ~ "android"  ',maxResults=100000)

android_testing = jira.search_issues('project = "test" AND issuetype = 故障 AND status = 測試中 AND text ~ "android"  ',maxResults=100000)

android_toDo = jira.search_issues('project = "test" AND issuetype = 故障 AND status = "To Do" AND text ~ "android"  ',maxResults=100000)

android_Highest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Highest AND text ~ "android" ',maxResults=100000)
android_High = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = High AND text ~ "android" ',maxResults=100000)
android_Medium = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Medium AND text ~ "android" ',maxResults=100000)
android_Low = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Low AND text ~ "android" ',maxResults=100000)
android_Lowest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Lowest AND text ~ "android" ',maxResults=100000)

#api:

api_done = jira.search_issues('project = "test" AND issuetype = 故障 AND status = Done AND text ~ "api"   ',maxResults=100000)

api_testing = jira.search_issues('project = "test" AND issuetype = 故障 AND status = 測試中  AND text ~ "api" ',maxResults=100000)

api_toDo = jira.search_issues('project = "test" AND issuetype = 故障 AND status = "To Do" AND text ~ "api"  ',maxResults=100000)

api_Highest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Highest AND text ~ "api" ',maxResults=100000)
api_High = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = High AND text ~ "api" ',maxResults=100000)
api_Medium = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Medium AND text ~ "api" ',maxResults=100000)
api_Low = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Low AND text ~ "api" ',maxResults=100000)
api_Lowest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Lowest AND text ~ "api" ',maxResults=100000)

#shuri

shuri_done = jira.search_issues('project = "test" AND issuetype = 故障 AND status = Done  AND text ~ "shuri" ',maxResults=100000)

shuri_testing = jira.search_issues('project = "test" AND issuetype = 故障 AND status = 測試中 AND text ~ "shuri"  ',maxResults=100000)

shuri_toDo = jira.search_issues('project = "test" AND issuetype = 故障 AND status = "To Do"  AND text ~ "shuri" ',maxResults=100000)

shuri_Highest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Highest AND text ~ "shuri" ',maxResults=100000)
shuri_High = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = High AND text ~ "shuri" ',maxResults=100000)
shuri_Medium = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Medium AND text ~ "shuri" ',maxResults=100000)
shuri_Low = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Low AND text ~ "shuri" ',maxResults=100000)
shuri_Lowest = jira.search_issues('project = RRPK AND issuetype = 故障 AND status = "To Do" AND priority = Lowest AND text ~ "shuri" ',maxResults=100000)



print ('\n\n        待辦          測試中     已完成')
print ('總:'+'       '+str(len(toDo))+'          '+str(len(testing))+'       '+str(len(done)))
print ('ios:        '+str(len(ios_toDo))+'('+str(len(ios_Highest))+'-'+str(len(ios_High))+'-'+str(len(ios_Medium))+'-'+str(len(ios_Low))+'-'+str(len(ios_Lowest))+')        '+str(len(ios_testing))+'       '+str(len(ios_done)))
print ('android:    '+str(len(android_toDo))+'('+str(len(android_Highest))+'-'+str(len(android_High))+'-'+str(len(android_Medium))+'-'+str(len(android_Low))+'-'+str(len(android_Lowest))+')        '+str(len(android_testing))+'       '+str(len(android_done)))
print ('api:        '+str(len(api_toDo))+'('+str(len(api_Highest))+'-'+str(len(api_High))+'-'+str(len(api_Medium))+'-'+str(len(api_Low))+'-'+str(len(api_Lowest))+')        '+str(len(api_testing))+'       '+str(len(api_done)))
print ('shuri:      '+str(len(shuri_toDo))+'('+str(len(shuri_Highest))+'-'+str(len(shuri_High))+'-'+str(len(shuri_Medium))+'-'+str(len(shuri_Low))+'-'+str(len(shuri_Lowest))+')        '+str(len(shuri_testing))+'     '+str(len(shuri_done)))

六、寫在最后

這個程序?qū)懙牟皇呛芎眉牛\行速度也比較慢转砖,總體上來說還可以,畢竟可以使用并且能達到我想要的需求

在這里只是為大家提供一個方向鲸伴,分享一下我學習這塊遇到的一些問題府蔗,希望對你有所幫助 ^ _ ^

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市汞窗,隨后出現(xiàn)的幾起案子姓赤,更是在濱河造成了極大的恐慌,老刑警劉巖仲吏,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件模捂,死亡現(xiàn)場離奇詭異,居然都是意外死亡蜘矢,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門综看,熙熙樓的掌柜王于貴愁眉苦臉地迎上來品腹,“玉大人,你說我怎么就攤上這事红碑∥杩裕” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵析珊,是天一觀的道長羡鸥。 經(jīng)常有香客問我,道長忠寻,這世上最難降的妖魔是什么惧浴? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮奕剃,結(jié)果婚禮上衷旅,老公的妹妹穿的比我還像新娘捐腿。我一直安慰自己,他們只是感情好柿顶,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布茄袖。 她就那樣靜靜地躺著,像睡著了一般嘁锯。 火紅的嫁衣襯著肌膚如雪宪祥。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天家乘,我揣著相機與錄音蝗羊,去河邊找鬼。 笑死烤低,一個胖子當著我的面吹牛肘交,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播扑馁,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼涯呻,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了腻要?” 一聲冷哼從身側(cè)響起复罐,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雄家,沒想到半個月后效诅,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡趟济,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年乱投,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片顷编。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡戚炫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出媳纬,到底是詐尸還是另有隱情双肤,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布钮惠,位于F島的核電站茅糜,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏素挽。R本人自食惡果不足惜蔑赘,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧米死,春花似錦锌历、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至物喷,卻和暖如春卤材,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背峦失。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工扇丛, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尉辑。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓帆精,卻偏偏與公主長得像,于是被迫代替她去往敵國和親隧魄。 傳聞我的和親對象是個殘疾皇子卓练,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1、通過CocoaPods安裝項目名稱項目信息 AFNetworking網(wǎng)絡(luò)請求組件 FMDB本地數(shù)據(jù)庫組件 SD...
    陽明先生_X自主閱讀 15,979評論 3 119
  • 當我拿到這本書的時候购啄,看到“慶山作品”這四個字襟企,還是有點不適應(yīng)。對于她狮含,我好像還停留在安妮寶貝顽悼。那時候她的感傷故事...
    許小圓要努力閱讀 516評論 0 0
  • 李亦杰點頭道:“原來如此。此去長安几迄,路途不下千里之遙蔚龙,你一個人太危險了,且由我們護送你一程吧映胁!”南宮雪大是驚訝木羹,怒...
    _____以歿炎涼閱讀 176評論 0 0
  • 2017年6月26日 星期一 晴 好長時間沒帶女兒出來遛彎了,今天考試結(jié)束了屿愚,也可以放松心情了,晚飯后帶著姐...
    仲蕊蕊媽媽閱讀 225評論 2 9
  • 秋草舊年長鶯飛 伊人一去再不回 一錢半夏 一兩當歸
    夢里玖閱讀 307評論 0 1