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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.02.2007, 10:39
novv75 novv75 вне форума
Прохожий
 
Регистрация: 02.02.2007
Сообщения: 23
Репутация: 10
Вопрос Запись поля dbf

Привет всем!!!
база данных dbf поле DDD тип С длина 6
на пятом месте всегда стоит дробь
например 3333/3 или 4444/4 нужно получить деление т.е 1111
Теоритически надо "вырезать" запись с первой по четвертую
и разделить на шестую а вот практически?
Как присвоить переменной значение поля?
Ответить с цитированием
  #2  
Старый 14.02.2007, 10:48
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Код:
var
  a,b:integer;
  c:Single;
  s:string;
begin
  ...
  s:=[тут твой DataSet].FieldByName('DDD').AsString;
  a:=StrToInt(copy(s,1,4));
  b:=StrToInt(copy(s,6,1));
  c:=a/b;
//как вариант, без a,b
  c:=StrToInt(copy(s,1,4))/StrToInt(copy(s,6,1));
//Можно и без s, сам догадайся как :)
end;
Ответить с цитированием
  #3  
Старый 14.02.2007, 13:46
novv75 novv75 вне форума
Прохожий
 
Регистрация: 02.02.2007
Сообщения: 23
Репутация: 10
По умолчанию

А как теперь значению другого поля ,допустим 'ааа', присвоить значение полученной переменной С
Ответить с цитированием
  #4  
Старый 14.02.2007, 13:57
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

А если справку почитать, или примеры, те что Demos посмотреть?
Ответить с цитированием
  #5  
Старый 15.02.2007, 13:23
novv75 novv75 вне форума
Прохожий
 
Регистрация: 02.02.2007
Сообщения: 23
Репутация: 10
По умолчанию

к сожалению английским не владею, а в своей деревне литературу найти трудно. Поэтому и задаю такие детские вопросы.
Ответить с цитированием
  #6  
Старый 15.02.2007, 13:42
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Код:
  [Твой DataSet].Edit;
  [Твой DataSet].FieldByName('AAA').AsFloat:=c;
  [Твой DataSet].Post;
Ответить с цитированием
  #7  
Старый 15.02.2007, 16:18
novv75 novv75 вне форума
Прохожий
 
Регистрация: 02.02.2007
Сообщения: 23
Репутация: 10
По умолчанию

Спасибо большое !!!
Ответить с цитированием
  #8  
Старый 16.02.2007, 09:36
novv75 novv75 вне форума
Прохожий
 
Регистрация: 02.02.2007
Сообщения: 23
Репутация: 10
По умолчанию

Сделал так кинул код на батон
var
s:string;
c:Single;
begin
s:=table2.FieldByName('DDD').asString;
c:= StrToInt(copy(s,1,4))/ StrToInt(copy(s,6,1));
table2.Edit ;
table2.FieldByName('AAA').AsFloat:=c;
table2.Post;
end;
выдает ошибку ''4444' is not a Valid integer value
что делать?
Ответить с цитированием
  #9  
Старый 16.02.2007, 10:47
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Значит данные у тебя в поле не такие как ты описал.

Специально проверил:
Код:
var
  c:Single;
  a:String;
begin
  a:='4444\4';
  c:=StrToInt(Copy(a,1,4))/StrToInt(Copy(a,6,1));
  ShowMessage(FloatToStr(c));
end;
Выдало 1111

Возможно поле в которое ты записываешь значение переменной у тебя целочисленное.

Тогда попробуй так:
Код:
var
s:string;
c:Integer;
begin
s:=table2.FieldByName('DDD').asString;
c:= StrToInt(copy(s,1,4)) div StrToInt(copy(s,6,1));
table2.Edit ;
table2.FieldByName('AAA').AsInteger:=c;
table2.Post;
end;
или так
Код:
var
s:string;
c:Single;
begin
s:=table2.FieldByName('DDD').asString;
c:= StrToInt(copy(s,1,4))/ StrToInt(copy(s,6,1));
table2.Edit ;
table2.FieldByName('AAA').AsInteger:=Trunc(c);
table2.Post;
end;
Ответить с цитированием
  #10  
Старый 16.02.2007, 14:40
novv75 novv75 вне форума
Прохожий
 
Регистрация: 02.02.2007
Сообщения: 23
Репутация: 10
По умолчанию

Да ошибка была в моих данных.
в поле Ddd стояли данные типа 4444/4, 444/4, 44/4
длина поля 6 дробь всегда на пятом месте
Если не сложно подскажи как игнорировать пробелы и работать только с целыми числами.
Ответить с цитированием
  #11  
Старый 17.02.2007, 10:16
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Цитата:
Сообщение от novv75
Да ошибка была в моих данных.
в поле Ddd стояли данные типа 4444/4, 444/4, 44/4
длина поля 6 дробь всегда на пятом месте
Если не сложно подскажи как игнорировать пробелы и работать только с целыми числами.


Функция срезающая начальные и конечные пробелы в строке - Trim
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter