Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
366 views
in Technique[技术] by (71.8m points)

ui automation - How can we fetch multiple data stored in <div> table in karate?

I am trying to fetch set of data from a web table, stored/made using the <div> tags, not like the traditional html data tables. For example:

    <div class="tabulator-cell" role="gridcell" tabulator-field="program_name" title="" style="width: 135px; text-align: left; height: 30px;">
        <span style="color: #007bff; font-weight: 500;">Consumer Banking</span>
        <div class="tabulator-col-resize-handle"></div>
        <div class="tabulator-col-resize-handle prev"></div>
    </div>
    <div class="tabulator-cell" role="gridcell" tabulator-field="business_value" title="" style="width: 111px; text-align: center; height: 30px;">
        11898
        <div class="tabulator-col-resize-handle"></div>
        <div class="tabulator-col-resize-handle prev"></div>
    </div>
    <div class="tabulator-cell" role="gridcell" tabulator-field="lead_time" title="" style="width: 95px; text-align: center; height: 30px;">
        28.26
        <div class="tabulator-col-resize-handle"></div>
        <div class="tabulator-col-resize-handle prev"></div>
    </div>
    <div class="tabulator-cell" role="gridcell" tabulator-field="avg_accomplishment_rate" title="" style="width: 83px; text-align: center; height: 30px;">
        59.15
        <div class="tabulator-col-resize-handle"></div>
        <div class="tabulator-col-resize-handle prev"></div>
    </div>
    <div class="tabulator-cell" role="gridcell" tabulator-field="backlog_health" title="" style="width: 123px; text-align: center; height: 30px;">
        2.08
        <div class="tabulator-col-resize-handle"></div>
        <div class="tabulator-col-resize-handle prev"></div>
    </div>
    <div class="tabulator-cell" role="gridcell" tabulator-field="agile_discipline" title="" style="width: 113px; text-align: center; height: 30px;">
        28.62
        <div class="tabulator-col-resize-handle"></div>
        <div class="tabulator-col-resize-handle prev"></div>
    </div>
    <div class="tabulator-responsive-collapse"></div>
</div>

Sample table

So, I am using scriptAll() method for this and need data just for 'Consumer Banking' here but unable to do so.

    * def list = scriptAll('div div', '_.textContent', function(x){ return x.contains('Consumer Banking') })
    * delay(3000)
    * print list 

Any help on this would be appreciated. Thanks in advance.

question from:https://stackoverflow.com/questions/65844733/how-can-we-fetch-multiple-data-stored-in-div-table-in-karate

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

I'll just give you one hint. This is how you can get a reference to the parent div of the row:

* def temp = locate('{}Consumer Banking').parent.parent

Now it is up to you:

* def businessValue = temp.locate("[tabulator-field='business_value']")
* match businessValue.text.trim() == '11898'

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...