Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.01.30;
Скачать: CL | DM;

Вниз

Вывод структуры таблицы   Найти похожие ветки 

 
Yurij-7   (2004-12-22 13:36) [0]

Уважаемые мастера подскажите в чем могут быть грабли при выведении структуры таблицы в ListBox, я делаю это вот так:

procedure TForm1.BitBtn2Click(Sender: TObject);
var
  Name, Typ: String;
  Len, Dec, i: Integer;
begin
//    for i := 1 to HalcyonDataSet1.FieldCount do
 begin
   with ListBox1.Items do
   begin

Add ("  "+Name+"   "+Typ+"   "+InttoStr(Len)+"   "+InttoStr (Dec)+"   ");

   end;
   end;

Но ксожалению в ListBox выыодит только нулевые значения Len Dec
Спасибо!


 
Александр Иванов ©   (2004-12-22 13:40) [1]

Комментарий со строки цикла снять?


 
Соловьев ©   (2004-12-22 13:40) [2]

Add ("  "+Name+"   "+Typ+"   "+InttoStr(Len)+"   "+InttoStr (Dec)+"   ");

а єто случем не поля HalcyonDataSet1.Fields[i]?


 
Johnmen ©   (2004-12-22 13:41) [3]

Ну всё правильно. Len Dec нигде не изменяются, инициализируются нулём..


 
Yurij-7   (2004-12-22 13:55) [4]

все исправил спасибо Johnmen & Соловьев  :))

А у меня еще вопрос как весь результат выровнять ну типа как по сетке в Экселе, длина имени поля то разная всегда.

Поле1     С   5   0
Поле2     С   5   0

Спасибо


 
Соловьев ©   (2004-12-22 13:57) [5]

TSringGrid или используй разделитель - табуляцию.


 
msguns ©   (2004-12-22 13:59) [6]

Или использовать шрифт с фиксированной шириной символов


 
Yurij-7   (2004-12-22 15:49) [7]

а можно чуть подробней "используй разделитель - табуляцию." просто я с TSringGrid никогда неработал :((
я думал сделать так:
1. вычислить длину имени поля (храниться в переменной)
2. недостающее количество символов в длине поля заполнить пробелами(только незнаюю пока как это делать)

или может есть проще вариант?
Спасибо


 
Yurij-7   (2004-12-22 17:23) [8]

ну неужели никто неподскажет?


 
msguns ©   (2004-12-22 17:24) [9]

>Yurij-7   (22.12.04 15:49) [7]
>я думал сделать так:
1. вычислить длину имени поля (храниться в переменной)
2. недостающее количество символов в длине поля заполнить пробелами(только незнаюю пока как это делать)

Если все поля -> в одну строку (вариант с "однострочными" списками типа листбокса), то этот метод сойдет. При условии выбора соотв.шрифта. Добавлять недостающие справа пробелы очень просто:
 While Lenght(S)<MaxLineLenght do S := S+" ";

Но будет некрасиво. Для красоты все же рекомендую TStringGrid. Правда там внутри ячеек нет автовыравнивания (по центру или направо) и если это все же желательно, то используй событие грида OnDrawCell с вычислением длины выражения и ширины ячейки и выравниваем первого относительно второй "вручную".
Не бойся сложностей. Когда получится - испытаешь оргазм ;)


 
Yurij-7   (2004-12-22 17:30) [10]

:))

А нету случайно статейки как работать с TStringGrid?


 
msguns ©   (2004-12-22 17:59) [11]

F1. Там достаточно хорошо все описано



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

Текущий архив: 2005.01.30;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.023 c
4-1102448133
mefisto
2004-12-07 22:35
2005.01.30
Передача "сигнала" программе.


3-1104169008
denis24
2004-12-27 20:36
2005.01.30
insert into temp....


1-1105691044
Zilog
2005-01-14 11:24
2005.01.30
Можно ли текстоввый файл запихнуть в DLL?


4-1101883890
Merfi
2004-12-01 09:51
2005.01.30
Переключение языка


1-1106033398
ghg
2005-01-18 10:29
2005.01.30
найти в TStringList строку содержащую определенный набор символов