Сортировать столбец (номер конкатенации и строку) по возрастанию и убыванию в PHP - PullRequest
0 голосов
/ 23 октября 2019

Я создал таблицу с использованием данных JSON в PHP и использовал несколько форматов для преобразования значений 1 переменной следующим образом:

if ($data[$i]->{'Volume'} < 1000) {
    $Volume[$i] = number_format($data[$i]->{'Volume'} , 2) ;
}else if ($data[$i]->{'Volume'} < 1000000) {
    $Volume[$i] = number_format($data[$i]->{'Volume'} / 1000, 2) . 'TH';
} else if ($data[$i]->{'Volume'} < 1000000000) {
    $Volume[$i] = number_format($data[$i]->{'Volume'} / 1000000, 2) . 'M';
} else {$Volume[$i] = number_format($data[$i]->{'Volume'} / 1000000000, 2) . 'B';}

Моя проблема заключается в том, что когда я использую сортировку в этом столбце, он учитываетстолбец не числовой и либо сортирует его, игнорируя, что они были в миллиардах или миллионах и т. д., либо не сортирует его

Я использовал два кода для сортировки данных, которые я использовал из https://www.w3schools.com/howto/howto_js_sort_table.asp. 1-й код сортирует данные в порядке возрастания и убывания. Однако он работает только на нечисловых данных. Другой код, который я использовал, предназначен для числовых значений, но не сортирует мой столбец данных.

Код, используемый для возрастания и убывания.

    <script>
function sortTable(n) {
var table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0;
  table = document.getElementById("myTable2");
  switching = true;
  // Set the sorting direction to ascending:
  dir = "asc"; 
  /* Make a loop that will continue until no switching has been done: */
  while (switching) {
    // Start by saying: no switching is done:
    switching = false;
    rows = table.rows;
    /* Loop through all table rows (except the first, which contains table headers): */
    for (i = 1; i < (rows.length - 1); i++) {
      // Start by saying there should be no switching:
      shouldSwitch = false;
      /* Get the two elements you want to compare, one from current row and one from the next: */
      x = rows[i].getElementsByTagName("TD")[n];
      y = rows[i + 1].getElementsByTagName("TD")[n];
      /* Check if the two rows should switch place, based on the direction, asc or desc: */
  if (dir == "asc") {
    if (x.innerHTML.toLowerCase() > y.innerHTML.toLowerCase()) {
      // If so, mark as a switch and break the loop:
      shouldSwitch = true;
      break;
    }
  } else if (dir == "desc") {
    if (x.innerHTML.toLowerCase() < y.innerHTML.toLowerCase()) {
      // If so, mark as a switch and break the loop:
      shouldSwitch = true;
      break;
    }
  }
}
if (shouldSwitch) {
  /* If a switch has been marked, make the switch
  and mark that a switch has been done: */
  rows[i].parentNode.insertBefore(rows[i + 1], rows[i]);
  switching = true;
  // Each time a switch is done, increase this count by 1:
  switchcount ++; 
} else {
  /* If no switching has been done AND the direction is "asc",
  set the direction to "desc" and run the while loop again. */
  if (switchcount == 0 && dir == "asc") {
    dir = "desc";
    switching = true;
  }
}
  }
}

Другой код, которыйя использовал для числовой сортировки. (это позволяет сортировать только малые и большие.

<script>
function sortTable(n) {
    var table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0;
    table = document.getElementById("tableData");
    switching = true;
    //Set the sorting direction to ascending:
    dir = "asc";
    /*Make a loop that will continue until
    no switching has been done:*/
    while (switching) {
        //start by saying: no switching is done:
        switching = false;
        rows = table.rows;
        /*Loop through all table rows (except the
        first, which contains table headers):*/
        for (i = 1; i < (rows.length - 1); i++) {
            //start by saying there should be no switching:
            shouldSwitch = false;
            /*Get the two elements you want to compare,
            one from current row and one from the next:*/
            x = rows[i].getElementsByTagName("TD")[n];
            y = rows[i + 1].getElementsByTagName("TD")[n];
            /*check if the two rows should switch place,
            based on the direction, asc or desc:*/
            if (Number(x.innerHTML) > Number(y.innerHTML)) {
                //if so, mark as a switch and break the loop:
                shouldSwitch = true;
                break;
            }
        }
        if (shouldSwitch) {
            /*If a switch has been marked, make the switch
            and mark that a switch has been done:*/
            rows[i].parentNode.insertBefore(rows[i + 1], rows[i]);
            switching = true;
        }
    }
}

Возможно ли иметь только одну функцию, которая будет сортировать как числовые, так и не числовые значения и оба способа (az, za,small-large, large-small), который также может обрабатывать числа, отформатированные в виде строки?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...