国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

幾行小代碼,將Testlink的xml用例導入至excel

2019-11-14 16:53:44
字體:
來源:轉載
供稿:網友

   最近在使用Testlink時,發現導入的用例是xml格式,且沒有合適的工具轉成Excel格式,xml使用excel打開顯示的東西也太多,網上也有相關工具轉成csv格式的,結果也不合人意。

  那求人不如爾己,自己寫一個吧

 需要用到的模塊有:xml.dom.minidom(python自帶)、xlwt

使用版本:

python:2.7.5

xlwt:1.0.0

一、先分析Testlink XML格式:

這是一個有兩級testusuit的典型的testlink用例結構,我們只需要取testsuite name,testcase name,PReconditions,actions,expectedresults

二、程序如下:

#coding:utf-8'''Created on 2015-8-20@author: Administrator'''''''''import xml.etree.cElementTree as ETimport xml.dom.minidom as xximport os,xlwt,datetimeworkbook=xlwt.Workbook(encoding="utf-8")# booksheet=workbook.add_sheet(u'sheet_1')booksheet.col(0).width= 5120booksheet.col(1).width= 5120booksheet.col(2).width= 5120booksheet.col(3).width= 5120booksheet.col(4).width= 5120booksheet.col(5).width= 5120dom=xx.parse(r'D://Python27/test.xml')root = dom.documentElementrow=1col=1borders=xlwt.Borders()borders.left=1borders.right=1borders.top=1borders.bottom=1style = xlwt.easyxf('align: wrap on,vert centre, horiz center')  #自動換行、水平居中、垂直居中#設置標題的格式,字體方宋、加粗、背景色:菊黃
#測試項的標題
title=xlwt.easyxf(u'font:name 仿宋,height 240 ,colour_index black, bold on, italic off; align: wrap on, vert centre, horiz center;pattern: pattern solid, fore_colour light_orange;')item='測試項'Subitem='測試分項'CaseTitle='測試用例標題'Condition='預置條件'actions='操作步驟'Result='預期結果'booksheet.write(0,0,item,title)booksheet.write(0,1,Subitem,title)booksheet.write(0,2,CaseTitle,title)booksheet.write(0,3,Condition,title)booksheet.write(0,4,actions,title)booksheet.write(0,5,Result,title)#凍結首行booksheet.panes_frozen=Truebooksheet.horz_split_pos= 1#一級目錄for i in root.childNodes: testsuite=i.getAttribute('name').strip() #print testsuite #print testsuite ''' 寫測試項 ''' print "row is :",row booksheet.write(row,col,testsuite,style) #二級目錄 for dd in i.childNodes: print " %s" % dd.getAttribute('name') testsuite2=dd.getAttribute('name') if not dd.getElementsByTagName('testcase'): print "Testcase is %s" % testsuite2 row=row+1 booksheet.write(row,2,testsuite2,style) #寫測試分項 row=row+1 booksheet.write(row,1,testsuite2,style) itemlist=dd.getElementsByTagName('testcase') for subb in itemlist: #print " %s" % subb.getAttribute('name') testcase=subb.getAttribute('name') row=row+1 booksheet.write(row,2,testcase,style) ilist=subb.getElementsByTagName('preconditions') for ii in ilist: preconditions=ii.firstChild.data.replace("<br />"," ") col=col+1 booksheet.write(row,3,preconditions,style) steplist=subb.getElementsByTagName('actions') #print steplist for step in steplist: actions=step.firstChild.data.replace("<br />"," ") col=col+1 booksheet.write(row,4,actions,style) #print "測試步驟:",steplist[0].firstChild.data.replace("<br />"," ") expectlist=subb.getElementsByTagName('expectedresults') for expect in expectlist: result=expect.childNodes[0].nodeValue.replace("<br />","" ) booksheet.write(row,5,result,style) row=row+1 workbook.save('demo.xls')

寫入excel的效果如下:

 

參考文檔:

1、python對excel操作:http://www.open-open.com/lib/view/open1385174954276.html

2、python之xml操作:http://www.jb51.net/article/63780.htm


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 前郭尔| 灌阳县| 荥阳市| 泽州县| 盐山县| 翁牛特旗| 樟树市| 余干县| 丰顺县| 梅河口市| 安塞县| 彩票| 成武县| 临清市| 临高县| 中宁县| 瓮安县| 巴里| 康定县| 江口县| 三河市| 西华县| 历史| 安溪县| 安宁市| 新民市| 花垣县| 南通市| 汤阴县| 资源县| 新余市| 长岭县| 高尔夫| 卢龙县| 中卫市| 永城市| 红河县| 隆化县| 尖扎县| 石城县| 湘潭市|