Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Фильтр массива (https://javascript.ru/forum/dom-window/66715-filtr-massiva.html)

laimas 06.01.2017 09:59

Я не понял закономерности того, чего ищется, но могу утверждать уверенно, что столько циклов для данной операции, это слишком. На вскидку, так тут вообще не нужны явные циклы, все вполне сделает array_reduce(), см. код рони, если его подправить, то это то чего и надо.

Sav2907 06.01.2017 10:00

laimas,
Вот только одну проблему немогу решить, 11 заказ сможете помочь?

laimas 06.01.2017 10:13

Цитата:

Сообщение от Sav2907
11 заказ сможете помочь?

Нет, ибо я так и не понял чего вы ищите, что за закономерность, как эти данные связаны. А без понимания этого нет и решения. Но, то что три цикла тут не нужны, а нужно:

$count = array_reduce($employeeid, function($carry, $item) use($employeeid) {
    //тут ищем, но чего, я не понял, и суммируем результат в $carry 
}, 0);


я убежден. А может и вообще и этого не надо.

Sav2907 06.01.2017 10:27

laimas,
Если честно, я тоже не понимаю что вам не понятно. Берется номер и проверяется использовался он ранее, проверка в Tool1Identifier и Tool2Identifier

рони 06.01.2017 10:33

Sav2907,
если текущая ячейка отличается от предыдущей по таким то правилам, то return $carry++ иначе просто $carry
если правильно сформулировать правила, то даже сами справитесь, какие они эти правила, пока только догадки

laimas 06.01.2017 10:48

Мне не сложно пояснить чего я не понимаю. Но начну с того, что в sql (каким sql сервером вы пользуетесь я не в курсе) существует понятие индекс. Если смотреть на вашу выборку и к примеру разрешать запись в поля Tool1Identifier и Tool2Identifier только уникальных значений, то прежде нужно ответить на вопрос "уникальности чего?", если для каждого поля, то уникальный индекс каждому полю, а если уникальность для набора двух полей, то составной индекс для этих полей.

Понимаете к чему я это? Если взять одну часть ваших пояснений, то можно предположить, что ищутся уникальные вхождения в обеих полях. Но в таком случае нужно взять значения этих полей, объединить их в один массив, удалить пустые значения, получить только уникальные значения полученного массива и подсчитать их количество. Все решение этого тогда сводится к следующему:

$cnt = count(array_unique(array_diff(array_merge(array_column($employeeid, "Tool1Identifier"), array_column($employeeid, "Tool2Identifier")), [null])));


Но как понять тогда позицию 13 где отмечено 265, 203, если 265 ранее уже встречалось? Так что вы ищите уникальное единичное значение в обеих полях или это плюс уникальность наборов?

Sav2907 06.01.2017 10:58

laimas,
Представим что перед вами два стола, на одном номер 265 на втором 205 (это позиция 10). Вы забираете 265 номер и ставите еще один 205 (это позиция 11), вот это и есть замена. Одна 205 должна была быть красной

laimas 06.01.2017 11:04

Нет в языке программирования понятий замена, есть к примеру уникальность. Если хотите пояснить что это такое "замена" поясните ее суть и закономерность, из приведенного выше, с пометкой красным, и с пояснений ранее я не понял ничего.
Если же пояснять категориями столов, тогда нужно пояснять сперва материю задачи, а по отрывкам.... Я понимаю, что вы понимаете того чего хотите, но я нет.

Sav2907 06.01.2017 11:17

Ладно, буду пробовать разруливать сам до конца. В любом случае, спасибо за помощь


Часовой пояс GMT +3, время: 16:43.