2017-01-13 9 views
-1

他の人のウェブページで結果のリストをソートしたいのですが。他の人のウェブページで結果を並べ替えるにはどうすればいいですか?

このウェブページでは、各結果アイテムが人気率で表示されています。彼らの人気に応じて結果を並べ替えたいと思います。

残念ながら、このウェブページではユーザーの分類オプションもAPIも提供されていません。

私はすべてのページをクロールし、人気率をHTMLコードで検索してから並べ替えることを考えていました。

あなたは何をお勧めしますか?何が最善の戦略ですか?

+0

どのような方法を試してみましたか?単に意見を求めるのではなく、改善できる具体的なコードを教えてください。オピニオンの質問は、スタックオーバーフローに関するトピック外です。 –

+0

これまでのところ、私は何も持っていません。コーディングする前に良い理論的な解決法を最初に尋ねるほうがいいと思った。 – lioli

+0

PhantomJSを試してみよう。 http://phantomjs.org –

答えて

0

結果の一覧が表として表示されている場合、人気が列であり、ブラウザを使用する場合は、Jesse Rudermanのsort table bookmarkletを使用できます。それは昇順または降順で並べ替えるために使用できる余分な列( "a/d")を各列の先頭に追加します。

javascript:function%20toArray%20(c){var%20a,%20k;a=new%20Array;for%20(k=0;%20k<c.length;%20++k)a[k]=c[k];return%20a;}function%20insAtTop(par,child){if(par.childNodes.length)%20par.insertBefore(child,%20par.childNodes[0]);else%20par.appendChild(child);}function%20countCols(tab){var%20nCols,%20i;nCols=0;for(i=0;i<tab.rows.length;++i)if(tab.rows[i].cells.length>nCols)nCols=tab.rows[i].cells.length;return%20nCols;}function%20makeHeaderLink(tableNo,%20colNo,%20ord){var%20link;link=document.createElement('a');link.href='javascript:sortTable('+tableNo+','+colNo+','+ord+');';link.appendChild(document.createTextNode((ord>0)?'a':'d'));return%20link;}function%20makeHeader(tableNo,nCols){var%20header,%20headerCell,%20i;header=document.createElement('tr');for(i=0;i<nCols;++i){headerCell=document.createElement('td');headerCell.appendChild(makeHeaderLink(tableNo,i,1));headerCell.appendChild(document.createTextNode('/'));headerCell.appendChild(makeHeaderLink(tableNo,i,-1));header.appendChild(headerCell);}return%20header;}g_tables=toArray(document.getElementsByTagName('table'));if(!g_tables.length)%20alert("This%20page%20doesn't%20contain%20any%20tables.");(function(){var%20j,%20thead;for(j=0;j<g_tables.length;++j){thead=g_tables[j].createTHead();insAtTop(thead,%20makeHeader(j,countCols(g_tables[j])))}})%20();function%20compareRows(a,b){if(a.sortKey==b.sortKey)return%200;return%20(a.sortKey%20<%20b.sortKey)%20?%20g_order%20:%20-g_order;}function%20sortTable(tableNo,%20colNo,%20ord){var%20table,%20rows,%20nR,%20bs,%20i,%20j,%20temp;g_order=ord;g_colNo=colNo;table=g_tables[tableNo];rows=new%20Array();nR=0;bs=table.tBodies;for(i=0;%20i<bs.length;%20++i)for(j=0;%20j<bs[i].rows.length;%20++j){rows[nR]=bs[i].rows[j];temp=rows[nR].cells[g_colNo];if(temp)%20rows[nR].sortKey=temp.innerHTML;else%20rows[nR].sortKey="";++nR;}rows.sort(compareRows);for%20(i=0;%20i%20<%20rows.length;%20++i)insAtTop(table.tBodies[0],%20rows[i]);} 

あなたはどのようなコードに興味があるなら:あなただけ(スペースがないことを確認してください)ドラッグ&ドロップし、それをあなたのブックマークツールバーにまたは対応するJavaScriptコードを使用して、ブックマークを作成する必要があり

あなたは、オンラインJavaScript美容師を使用してそれを美化することができます。これはあなたが得るものです:

javascript: function toArray(c) { 
    var a, k; 
    a = new Array; 
    for (k = 0; k < c.length; ++k) a[k] = c[k]; 
    return a; 
} 

function insAtTop(par, child) { 
    if (par.childNodes.length) par.insertBefore(child, par.childNodes[0]); 
    else par.appendChild(child); 
} 

function countCols(tab) { 
    var nCols, i; 
    nCols = 0; 
    for (i = 0; i < tab.rows.length; ++i) 
     if (tab.rows[i].cells.length > nCols) nCols = tab.rows[i].cells.length; 
    return nCols; 
} 

function makeHeaderLink(tableNo, colNo, ord) { 
    var link; 
    link = document.createElement('a'); 
    link.href = 'javascript:sortTable(' + tableNo + ',' + colNo + ',' + ord + ');'; 
    link.appendChild(document.createTextNode((ord > 0) ? 'a' : 'd')); 
    return link; 
} 

function makeHeader(tableNo, nCols) { 
    var header, headerCell, i; 
    header = document.createElement('tr'); 
    for (i = 0; i < nCols; ++i) { 
     headerCell = document.createElement('td'); 
     headerCell.appendChild(makeHeaderLink(tableNo, i, 1)); 
     headerCell.appendChild(document.createTextNode('/')); 
     headerCell.appendChild(makeHeaderLink(tableNo, i, -1)); 
     header.appendChild(headerCell); 
    } 
    return header; 
} 
g_tables = toArray(document.getElementsByTagName('table')); 
if (!g_tables.length) alert("This page doesn't contain any tables."); 
(function() { 
    var j, thead; 
    for (j = 0; j < g_tables.length; ++j) { 
     thead = g_tables[j].createTHead(); 
     insAtTop(thead, makeHeader(j, countCols(g_tables[j]))) 
    } 
})(); 

function compareRows(a, b) { 
    if (a.sortKey == b.sortKey) return 0; 
    return (a.sortKey < b.sortKey) ? g_order : -g_order; 
} 

function sortTable(tableNo, colNo, ord) { 
    var table, rows, nR, bs, i, j, temp; 
    g_order = ord; 
    g_colNo = colNo; 
    table = g_tables[tableNo]; 
    rows = new Array(); 
    nR = 0; 
    bs = table.tBodies; 
    for (i = 0; i < bs.length; ++i) 
     for (j = 0; j < bs[i].rows.length; ++j) { 
      rows[nR] = bs[i].rows[j]; 
      temp = rows[nR].cells[g_colNo]; 
      if (temp) rows[nR].sortKey = temp.innerHTML; 
      else rows[nR].sortKey = ""; 
      ++nR; 
     } 
    rows.sort(compareRows); 
    for (i = 0; i < rows.length; ++i) insAtTop(table.tBodies[0], rows[i]); 
} 
関連する問題