Скопировать строки из одной таблицы в другую, используя расширенный фильтр, передаваемый в виде таблицы.


На примере показано как скопировать из таблицы 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 - при собпадении данных у строк по ключевой колонке - суммировать числовые значения;