Как считать плавание из двоичного файла в C?

Это - вопрос вкуса.

Это - мое предпочтение.

SELECT 
  column1
 ,column2
FROM
  table1
WHERE column3 IN (
                 SELECT TOP(1) column4
                 FROM 
                   table2
                   INNER JOIN table3
                 ON table2.column1 = table3.column1
                 )
6
задан Polaris878 14 September 2009 в 17:24
поделиться

7 ответов

То, как вы должны читать числа с плавающей запятой из файла, полностью зависит от того, как значения были сохранены там в первую очередь. Один из распространенных способов может быть следующим:

void writefloat(float v, FILE *f) {
  fwrite((void*)(&v), sizeof(v), 1, f);
}

float readfloat(FILE *f) {
  float v;
  fread((void*)(&v), sizeof(v), 1, f);
  return v;
}
18
ответ дан 8 December 2019 в 03:01
поделиться
float f;
if(read(fd,&f,sizeof(f))==sizeof(f))
    printf("%f\n",f);
else
    printf("oops\n");

При условии, что он записан как совместимое двоичное представление.

read для файловых дескрипторов, fread для FILE * s и ] istream :: read для c ++ iostreams. Выберите все, что вам нравится:

read(fd,&f,sizeof(f))==sizeof(f)

fread(&f,sizeof(f),1,fp)==1

fin.read((char*)&f,sizeof(f)).gcount()==sizeof(f)
5
ответ дан 8 December 2019 в 03:01
поделиться

Вы можете использовать fread . (Обратите внимание, что API предназначен для C, хотя на веб-сайте написано «Ссылка на C ++» :))

3
ответ дан 8 December 2019 в 03:01
поделиться

Используйте fread () из . Утверждения следует заменить фактическим кодом обработки ошибок.

#include <stdio.h>
#include <assert.h>

#define countof(ARRAY) (sizeof (ARRAY) / sizeof *(ARRAY))

float data[5];

FILE *file = fopen("foo.bin", "rb");
assert(file);

size_t n = fread(data, sizeof(float), countof(data), file);
assert(n == countof(data));

Имейте в виду, что вы можете столкнуться с проблемами с порядком байтов, если вы переносите файлы между разными архитектурами.

2
ответ дан 8 December 2019 в 03:01
поделиться

Если файл полностью "плавающий" и вы хотели прочитать его X раз, все, что вам нужно сделать, это:

FILE *fp;

if((fp=fopen("filename.whatever", "rb"))==NULL)
 return 0;

fseek(fp, 0, SEEK_END);
long size = ftell(fp);
fseek(fp, 0, SEEK_SET);

float *f = (float *)malloc(sizeof(float)*size);
if(f==NULL)
{
 fclose(fp);
 return 0;
}

if(fread(f, sizeof(float), size, fp)!=size)
{
 fclose(fp);
 return 0;
}

fclose(fp);

// do something with f
2
ответ дан 8 December 2019 в 03:01
поделиться
FILE *thisFile=fopen("filename","fb");
float myFloat;
fscanf(thisFile,"%f",&myFloat);
fclose(thisFile);

Это работает, если данные записываются с использованием fprintf (зависит от реализации)
Однако вы также можете преобразовать тип float в int32 и сохранить , загрузка и приведение типов.

std::fstream thisFile;
thisFile.open("filename",ios::read|ios::binary);
float myFloat;
thisFile>>myFloat;
thisFile.close();

Может быть, ошибаюсь (я давно не использовал функции C ++ F.IO)

1
ответ дан 8 December 2019 в 03:01
поделиться

Если эти значения последовательно помещаются в двоичный файл, вы можете выполнить чтение sizeof (float) байтов на одно значение с плавающей запятой в массив символов. Затем вы можете преобразовать их в значение с плавающей запятой.

0
ответ дан 8 December 2019 в 03:01
поделиться
Другие вопросы по тегам:

Похожие вопросы: