Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2010.11.14;
Скачать: [xml.tar.bz2];

Вниз

DBgridEh ошибка фильтре Error in expression   Найти похожие ветки 

 
Ulugbek   (2009-03-11 14:57) [0]

Привет всем.
Помогите с фильтрем в DbgridEh .
Когда фильтр делаю по одной поле выдает ошибку
Error in expression.. а остальними нет..
В поля содержит такого значения
(095) 949-959-59
если фильтре так напишу то ругаеться..
Помогите в чем проблема..


 
Немо ©   (2009-03-11 15:09) [1]

как то встречалось, что он скобки не понимает
попытайтесь без скобок как-то сделать, изменить фильтр


 
Ulugbek   (2009-03-11 15:49) [2]

Просто у меня пользователь хотел что фильтр был как у Excel и автоматом фильтровал..
Сделал так
соединил Tibclientdataset>DataDriverEh>MemTable>Datasource..
В DbGrideH>stfilter=true ,visible=true server и local sortin=true;

Добавил Uses EhlibIBX.pas и в модуле
initialization
 DBGridEhDefaultStyle.FilterEditCloseUpApplyFilter := True;
что бы автоматом фильтр делал и все.
В поля содержит такого значения
(095) 949-959-59 если я вот так напишу то он не ругает "(095) 949-959-59"
Может Dbgrideh.pas поправить?


 
Ulugbek   (2009-03-18 12:55) [3]

Помогите а !
Никто  не сталкивался с таким Errorom :(


 
немо2   (2009-03-18 13:07) [4]

>> если я вот так напишу то он не ругает "(095) 949-959-59"
проблема решена? ->>  ну так и пиши!
не устраивает? ->> поправь Dbgrideh.pas


 
Ulugbek   (2009-03-18 14:47) [5]


> >> если я вот так напишу то он не ругает "(095) 949-959-
> 59"
> проблема решена? ->>  ну так и пиши!
> не устраивает? ->> поправь Dbgrideh.pas
>


Это пользователю не нравится писать с апострами...
Вот я незнаю именно что изменить в DbgridEh.pas..
Если знаешь помоги очень надо..


 
немо2   (2009-03-18 14:52) [6]

трогать исходники не надо по возможности бы

>> пользователю не нравится писать с апострами
так пусть не пишет
он напишет как нравится, а ты будешь подставлять QuotedStr(от того что он напишет)


 
Ulugbek   (2009-03-18 15:15) [7]

но как буду вставить QuotedStr если он из списка выберить..
Или где я буду поставить это . Я в фильре ничего не писал это оно автоматом должно правильно..
Пример плиз.


 
Ulugbek   (2009-03-18 15:23) [8]

Где, куда
OnApplyfiltr Писать? Пример.. Плииз


 
немо2   (2009-03-18 15:56) [9]

>>  OnApplyfiltr
тебе виднее

а вообще, скобки он рассматривает похоже как сложный фильтр, для доп. условий
если в DbUtilsEh.pas вот это место
 begin
   for i := Pos to Length(S) do
   begin
     if ((S[i] in [" "]) and CheckForOperand(S, SkipBlanks(S, i))) or
       ((S[i] in [")", "("])) or
       (PreferCommaForList and (S[i] = ",")) then

     begin
       Result := Copy(S, Pos, i - Pos);
       Pos := i;
       Exit;
     end;
   end;
   Result := Copy(S, Pos, MAXINT);
   Pos := Length(S) + 1;
 end;
переправить, может и получится..


 
Ulugbek   (2009-03-18 16:13) [10]

:( Как?


 
немо2   (2009-03-18 16:22) [11]


>    for i := Pos to Length(S) do
>    begin
>      if ((S[i] in [" "]) and CheckForOperand(S, SkipBlanks(S,
>  i))) or
>        ((S[i] in [")", "("])) or
>        (PreferCommaForList and (S[i] = ",")) then
>      begin
>        Result := Copy(S, Pos, i - Pos);
>        Pos := i;
>        Exit;
>      end;
>    end;

выкинуть


 
Ulugbek   (2009-03-18 16:39) [12]

:)) Да не помогло
var
 i: Integer;
begin
 Result := Null;
 if Pos > Length(S) then
   Exit;
 if S[Pos] = """" then
 begin
   for i := Pos + 1 to Length(S) do
     if S[i] = """" then
     begin
       Result := Copy(S, Pos + 1, i - Pos - 1);
       Pos := i + 1;
       Exit;
     end;
   raise Exception.Create(SQuoteIsAbsentEh + S);
 end;
 {else                    Коментировал
 begin
   for i := Pos to Length(S) do
   begin
     if (CharInSet(S[i], [" "]) and CheckForOperand(S, SkipBlanks(S, i))) or
       (CharInSet(S[i], [")", "("])) or
       (PreferCommaForList and (S[i] = ",")) then
     begin
       Result := Copy(S, Pos, i - Pos);
       Pos := i;
       Exit;
     end;
   end;
   Result := Copy(S, Pos, MAXINT);
   Pos := Length(S) + 1;
 end;}
end;


 
Ulugbek   (2009-03-18 17:23) [13]

НЕМО2
Вот для примера тест http://ifolder.ru/11116769
я DBUtilsEh коментировал
{else                    Коментировал
begin
  for i := Pos to Length(S) do
  begin
    if (CharInSet(S[i], [" "]) and CheckForOperand(S, SkipBlanks(S, i))) or
      (CharInSet(S[i], [")", "("])) or
      (PreferCommaForList and (S[i] = ",")) then
    begin
      Result := Copy(S, Pos, i - Pos);
      Pos := i;
      Exit;
    end;
  end;
  Result := Copy(S, Pos, MAXINT);
  Pos := Length(S) + 1;
end;}

Но все равно ругает..


 
немо2   (2009-03-18 17:37) [14]

1 нет у меня rar, ибо платный
2 EhLib 3.6 у меня, у тебя какая?
3
begin
 
{
for i := Pos to Length(S) do
  begin
    if ((S[i] in [" "]) and CheckForOperand(S, SkipBlanks(S, i))) or
      ((S[i] in [")", "("])) or
      (PreferCommaForList and (S[i] = ",")) then
    begin
      Result := Copy(S, Pos, i - Pos);
      Pos := i;
      Exit;
    end;
  end;
}

  Result := Copy(S, Pos, MAXINT);
  Pos := Length(S) + 1;
end;
вот что если закоментить?


 
Ulugbek   (2009-03-18 17:41) [15]

у меня Ehlib 4.2.16//
Завтра отпишусь резултат
Ok пасибо


 
немо2   (2009-03-18 17:45) [16]

а Ehlib 4.2.16 - тоже платная. Или уже нет?


 
Ulugbek   (2009-03-19 08:12) [17]

Привет всем!
НЕМО2
нет не получился.. Все равно ругает..
EHLIB Ehlib 4.2.16 платная


 
Ulugbek   (2009-03-19 14:08) [18]

НЕМО2
помоги если не устал Ж(


 
turbouser ©   (2009-03-19 16:51) [19]


> Ulugbek   (19.03.09 08:12) [17]
>
> EHLIB Ehlib 4.2.16 платная

Если куплена - есть саппорт.


 
немо2   (2009-03-19 17:34) [20]

а если в процедуре добавить в
--
--

procedure TCustomDBGridEh.SetFilterValue(DCol: Integer);
var
 Column: TColumnEh;
begin
 if (DCol < 0) or (DCol >= Columns.Count) then
   Exit;
 Column := Columns[DCol];
 if Column.FieldName <> ""
--
and Pos("(", FilterEdit.Text) > 0)
and Pos(")", FilterEdit.Text) > 0)

--
then
   Column.STFilter.InternalSetExpressionStr(FilterEdit.Text);
//    if Column.STFilter.KeyField <> ""
//      then Column.STFilter.SetKeyListValues(FilterEdit.Text, FilterEdit.Value)
//      else Column.STFilter.InternalSetExpressionStr(FilterEdit.Text);
end;


 
Ulugbek   (2009-03-20 09:58) [21]

Нет не помогло... Капитан НЕМО2
в инете нашел такой способ но это тоже не работает..

DbgridEh.pas добавил функцию function CheckFilter(AFilterEdit: string): boolean;
наверх процедуры procedure TCustomDBGridEh.SetFilterValue(DCol: Integer);
Этот вариант тоже не сработало почемуто или мне функцию обявить наверху?

function CheckFilter(AFilterEdit: string): boolean;
begin
 result := true;
 if (Length(AFilterEdit) > 0)
     and (AFilterEdit <> "(Order by ascending)") and (AFilterEdit <> "(Order by descending)")
     and (ANSIPos("(", AFilterEdit) > 0) and (ANSIPos(")", AFilterEdit) > 0) then begin
   result := false;
 end;
end;

procedure TCustomDBGridEh.SetFilterValue(DCol: Integer);
var
 Column: TColumnEh;
begin
 if (DCol < 0) or (DCol >= Columns.Count) then
   Exit;
 Column := Columns[DCol];
 if (Column.FieldName <> "") CheckFilter(FilterEdit.Text) then
   Column.STFilter.InternalSetExpressionStr(FilterEdit.Text);
//    if Column.STFilter.KeyField <> ""
//      then Column.STFilter.SetKeyListValues(FilterEdit.Text, FilterEdit.Value)
//      else Column.STFilter.InternalSetExpressionStr(FilterEdit.Text);
end;


Или мне переходить на Ehlib 3.6


 
немо2   (2009-03-20 12:30) [22]

все-таки надо с кавычками, имхо, разобраться. С ними же работает

или фильтрвать сам датасет
procedure TForm1.DBGridEh1ApplyFilter(Sender: TObject);
begin
 dataset.Filtered:=false;
 dataset.Filter:=DBGridEh1.Columns[нужный].STFilter.ExpressionStr;
 dataset.Filtered:=true;
end;


 
Гостья-1245 ©   (2009-07-10 15:40) [23]

все проще, хотя может вы уже и нашли ответ,
спасибо ВАМ - я знала что искать, так вот:

в DbUtilsEh
надо заремить всего одну строку
egin
 Result := Null;
 if Pos > Length(S) then
   Exit;
 if S[Pos] = """" then
 begin
   for i := Pos + 1 to Length(S) do
     if S[i] = """" then
     begin
       Result := Copy(S, Pos + 1, i - Pos - 1);
       Pos := i + 1;
       Exit;
     end;
   raise Exception.Create(SQuoteIsAbsentEh + S);
 end
 else
 begin
   for i := Pos to Length(S) do
   begin
     if ((S[i] in [" "]) and CheckForOperand(S, SkipBlanks(S, i))) or
//ВОТ ЭТУ        ((S[i] in [")", "("])) or
       (PreferCommaForList and (S[i] = ",")) then
     begin
       Result := Copy(S, Pos, i - Pos);
       Pos := i;
       Exit;
     end;
   end;
   Result := Copy(S, Pos, MAXINT);
   Pos := Length(S) + 1;
 end;


 
turbouser ©   (2009-07-10 20:42) [24]


> Гостья-1245 ©

См. [19]


 
sdsk ©   (2009-07-14 12:29) [25]

Там еще проблема. Если фильтр выставлен лукапом, то не работает на половине полей. Все руки никак не дойдут разобраться со всеми этими глюками фильтрации ehlib. Автор компонентов эту простейшую задачу кажется не собирается исправлять.

Кстати чего версия такая старая? 4.6 уже есть



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2010.11.14;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.51 MB
Время: 0.004 c
15-1280736014
ocean
2010-08-02 12:00
2010.11.14
Выбрать ОС


15-1281040197
Юрий
2010-08-06 00:29
2010.11.14
С днем рождения ! 6 августа 2010 пятница


15-1280438963
Германн
2010-07-30 01:29
2010.11.14
W7 90-days trial version


15-1280996881
abun
2010-08-05 12:28
2010.11.14
Как программно отследить события


2-1282022380
12
2010-08-17 09:19
2010.11.14
Как писать запросы к таблицам dbf





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский