Руководство по LABPP_Automat для ARCHICAD
Скопировать строки из одной таблицы в другую, используя расширенный фильтр, передаваемый в виде таблицы.
На примере показано как скопировать из таблицы iTable в iTableFiltered все записи без суммирования числовых переменных одинаковых строк у которых в колонке с названием "Колонка1" значение "СТЕНА", значение в колонке "Колонка2" - содержит "3", в колонке "Колонка3" содержится в любом месте "В22" или "В22" (В - или на русском или на английском) и в колонке "Колонка 4" число больше или равное 2.
bool stoponfirstnoteq = false;
bool add_sum = false;
int iTableFilter;
object("create", "ts_table", iTableFilter);
ts_table(iTableFilter, "create_structure_for_filter_table");
ts_table(iTableFilter, "add_row_to_filter_table", "(", "ANY", "Колонка1", "=", "СТЕНА", "", "AND");
ts_table(iTableFilter, "add_row_to_filter_table", "", "ANY", "Колонка2", "CONTAINS", "3", "", "AND");
ts_table(iTableFilter, "add_row_to_filter_table", "", "ANY", "Колонка3", "REGEXMACH", ".*[BВ]22.*", "", "AND");
ts_table(iTableFilter, "add_row_to_filter_table", "", "ANY", "Колонка4", ">=", 2, ")", "");
ts_table(iTableFiltered, "add_rows_from_eq_table_by_extended_filter", iTable, bool stoponfirstnoteq, bool add_sum);
Здесь
iTableFiltered - дескриптор таблицы, в которую будут копироваться строки из таблицы iTable;
stoponfirstnoteq - остановить копирование при первом столкновении с неподходящей строкой;
add_sum - при собпадении данных у строк по ключевой колонке - суммировать числовые значения;