Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 06.03.2013, 12:51
SadKnight SadKnight вне форума
Прохожий
 
Регистрация: 06.03.2013
Сообщения: 4
Репутация: 10
Вопрос Преобразование из Byte в Str

Здравствуйте!
Прошу помочь. Имеется база данных, в ней таблица. В таблице один столбец имеет тип Byte и длину 10. Мне необходимо преобразовать ее в String.
Если просто обращаться к ней напрямую(DBGrid1.DataSource.dataSet.fieldByName('Code').Val ue), то у меня получается "C?*??????" и подобная кракозябра.
Мне необходимо получить результат строки к примеру в таком виде "013253E177882480004E"

Последний раз редактировалось SadKnight, 06.03.2013 в 12:56.
Ответить с цитированием
  #2  
Старый 06.03.2013, 12:57
Аватар для angvelem
angvelem angvelem вне форума
.
 
Регистрация: 18.05.2011
Адрес: Омск
Сообщения: 3,970
Версия Delphi: 3,5,7,10,12,XE2
Репутация: выкл
По умолчанию

IntToHex для преобразования.
__________________
Je venus de nulle part
55.026263 с.ш., 73.397636 в.д.
Ответить с цитированием
Этот пользователь сказал Спасибо angvelem за это полезное сообщение:
SadKnight (06.03.2013)
  #3  
Старый 06.03.2013, 12:59
SadKnight SadKnight вне форума
Прохожий
 
Регистрация: 06.03.2013
Сообщения: 4
Репутация: 10
По умолчанию

Цитата:
Сообщение от angvelem
IntToHex для преобразования.

Если я правильно понимаю.

Код:
var i: Integer;
Begin
i := DBGrid1.DataSource.dataSet.fieldByName('Code').Value;
Edit1.Text := IntToHex(i);
end;

К сожалению компилятор выдает ошибку "Could not convert variant of type(Array Byte) into type(Integer)"

Последний раз редактировалось SadKnight, 06.03.2013 в 13:15.
Ответить с цитированием
  #4  
Старый 06.03.2013, 13:18
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

используй cast в sql-запросе
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #5  
Старый 06.03.2013, 13:30
SadKnight SadKnight вне форума
Прохожий
 
Регистрация: 06.03.2013
Сообщения: 4
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
используй cast в sql-запросе

Я открываю таблицу не через query.
Ответить с цитированием
  #6  
Старый 06.03.2013, 13:51
SadKnight SadKnight вне форума
Прохожий
 
Регистрация: 06.03.2013
Сообщения: 4
Репутация: 10
По умолчанию

В общем решение такое
Код:
for i:= 0 to 19 do
begin
t[i] := DBGrid1.DataSource.dataSet.fieldByName('Code').Value[i];
tu:=t[i];
zu:=zu+IntToHex(tu,1);
end;
edit1.Text := zu;
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 23:50.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025