Сортировка в таблице quik

Страницы: 1
RSS
Сортировка в таблице quik
 
Всем привет!
Пытался найти ответ на форуме, но так и не нашел конкретики: в основом "вокруд да около".

Коротко: напервом этапе вытаскиваю объемы в деньгах

for j=1, #tickers do
Valtod[j] = getParamEx("TQBR", tickers[j], "VALTODAY").param_image;
end

Создаю таблицу и колоку 8 для вставки полученных выше значений

AddColumn(tabl, 8, "ValToday", true, QTABLE_INT_TYPE, 15);

Далее вставляю значения

for i=1, #tickers do
SetCell(tabl,i,8,tostring(Valtod[i]))
end


Получаю вот такую красоту, котрая не сортируется встроенным сортировщиком.
[img][/img]

1. если использовать вместо param_image     param_value вроде как числовые "некрасивые" значения подтягиваются, но это не помогает
2. если задавать вместо QTABLE_INT_TYPE стриг - не помогает
3. если вот тут SetCell(tabl,i,8,tostring(Valtod[i])) убрать стриг - вообще не выводит ничего
 
"Красота" вот тут
 
 
Попробуйте так

SetCell(tabl,i,8,tostring(Valtod[i]) , Valtod[i])
 
Спасибо за мысль!

Решил следующим способом: ввел 2 параметра для каждого тикера
 
вот продолжение предыдущего постав =)

Valtodi[j] = tostring(getParamEx("TQBR", tickers[j], "VALTODAY").param_image);
Valtodv[j] = tonumber(getParamEx("TQBR", tickers[j], "VALTODAY").param_value);

Далее SetCell(tabl,i,8,Valtodi[i],Valtodv[i])  - передаю текстовые и числове значения (как описании)

BOOLEAN SetCell(NUMBER t_id, NUMBER key, NUMBER code, STRING text, NUMBER value)

+ еще нужно было поменять на INT64 тип

AddColumn(tabl, 8, "ValToday", true, QTABLE_INT64_TYPE, 15);

Вуаля - и сортировка кликом заработала в таблице
 
В функции SetCell есть 5 параметр «NUMBER value», который якобы отвечает за сортировку в столбце. Не подскажите правила работы с ним?
 
is_run = true;


function OnInit()

tikers = {
"AFKS" , "AFLT" , "AGRO" , "ALRS" , "CBOM" , "CHMF" , "ENPG" , "FEES" , "FIVE" , "FIXP" , "GAZP" , "GLTR" , "GMKN" , "HYDR" , "IRAO" , "LKOH" , "MAGN" , "MGNT" , "MOEX" , "MTSS" , "NLMK" , "NVTK" , "OZON" , "PHOR" , "PIKK" , "PLZL" , "POLY" , "ROSN" , "RTKM" , "RUAL" , "SBER" , "SBERP" , "SGZH" , "SNGS" , "SNGSP" , "TATN" , "TATNP" , "TCSG" , "TRNFP" , "VKCO" , "VTBR" , "YNDX"
}   --- акции - бумаги

end

function OnStop()
DestroyTable(m_t)
do_it = false

end






function main()


if m_t==nil then    
m_t=AllocTable()
AddColumn(m_t, 1, "Тикер", true, QTABLE_STRING_TYPE, 15)

AddColumn(m_t, 2, "Бумага", true, QTABLE_STRING_TYPE, 20)

AddColumn(m_t, 3, "Цена закрытия", true, QTABLE_STRING_TYPE, 50)
CreateWindow(m_t)
SetWindowPos(m_t,0,430,700,400)

SetWindowCaption(m_t, "Моя таблица")
end

for u = 1, #tikers do
InsertRow(m_t,-1)
local tName = getParamEx("TQBR", tikers[u], "SHORTNAME")
local tLast = getParamEx("TQBR", tikers[u], "PREVPRICE")

SetCell(m_t, u, 1, tikers[u])
SetCell(m_t, u, 2, tName.param_image)
SetCell(m_t, u, 3, tLast.param_image,0)

end

while is_run do
sleep(300)
end
end



Можно ли  данную таблицу ПРАВИЛЬНО сортировать по 3 столбцу???
 
Вот описание SetCell, может, пригодится:

Функция задает значение для ячейки в строке с ключом key, кодом колонки code в таблице t_id. Параметр text задает строковое представление значение параметра value. Параметр value необязательный и по умолчанию равен 0. Для столбцов со строковыми типами данных параметр value не задается. Если параметр value не задан для ячеек всех остальных типов, то по столбцам, содержащим такие ячейки, не будет корректно работать сортировка, фильтрация и условное форматирование (см. Приложение 2). Функция возвращает true в случае успешного завершения, иначе – false.

Формат вызова:
BOOLEAN SetCell(NUMBER t_id, NUMBER key, NUMBER code, STRING text, NUMBER value)
 
Спасибо. Данное описание из справочника QLUA. Я хотел бы разобраться именно с последним входящим параметром NUMBER value. Какие должны быть данные параметры для различных ситуаций. Что неправильно в предыдущем коде для адекватной правильной сортировки?
 
Цитата
Lelikov написал:
Спасибо. Данное описание из справочника QLUA. Я хотел бы разобраться именно с последним входящим параметром -- NUMBER value. Какие должны быть данные параметры для различных ситуаций. Что неправильно в предыдущем коде для адекватной правильной сортировки?
 
Цитата
Lelikov написал:
Спасибо. Данное описание из справочника QLUA. Я хотел бы разобраться именно с последним входящим параметром NUMBER value. Какие должны быть данные параметры для различных ситуаций. Что неправильно в предыдущем коде для адекватной правильной сортировки?
Вы же его везде в 0 поставили. Хотите нули сортировать?) В справке сказано "Параметр text задает строковое представление значение параметра value.", что очевидно значит, что эти два параметра должны соответствовать друг другу (например, быть равными после приведения типов). А у Вас text меняется, а value всегда 0.
 
Спасибо. Правильно полагаю, 5-ый параметр value - числовой для сортировки, 4-ый параметр - text  строка для отображения в ячейке?
 
Цитата
Lelikov написал:
Спасибо. Правильно полагаю, 5-ый параметр "value" - числовой для числовых действий в т.ч. для сортировки, 4-ый параметр - "text"  аналог 5-го параметра, только тип - строка, он для отображения 5-го параметра в указанной ячейке?
Страницы: 1
Читают тему
Наверх