Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
pavlenko2k16
1 / 1 / 1
Регистрация: 24.09.2016
Сообщений: 131
Завершенные тесты: 1
#1

Чтение массива структур из бинарного файла - C++

24.11.2016, 20:30. Просмотров 184. Ответов 6
Метки нет (Все метки)

при выводе дает какую-то кашу из символов
переписываю структуру из одного файла в 10. это необходимо для внешней сортировки слиянием
C++
1
2
3
4
5
6
7
 fstream buf10("buf10.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks, sizeof(tick));
    buf10.write((char*)&ticks,sizeof(tick));
    cout << ticks << " ";
Sort (buf10, step);
    }
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void Sort (fstream& buf, int num) {
    buf.seekg(0); 
    tick ticks[num];
    
    for (int i = 0; i < num; i++)
    buf.read((char*)&ticks[i], sizeof(tick));
    
    for (int i = 0; i < num; i++)
    for (int j = 0; j < (num - 1); j++) {
    if (ticks[i].name > ticks[i + 1].name)
    swap (ticks[i].name, ticks[i + 1].name);
    cout << endl << ticks[i].name << " " << ticks[i + 1].name;
    }
}
Добавлено через 6 минут
C++
1
2
3
4
5
6
    fstream buf10("buf10.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf10.write((char*)&ticks[0],sizeof(tick));
    }
    Sort (buf10, step);
Добавлено через 7 минут
проблема с передачей в функцию
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.11.2016, 20:30
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Чтение массива структур из бинарного файла (C++):

Чтение массива структур из бинарного файла - C++
Доброго времени суток.Возникла проблема с чтением структур из бинарного файла.Файл открывает,но при считывании данных, сразу закрывается с...

Чтение нескольких структур и одной переменной из бинарного файла. Формат файла имеется - C++
Формат файла состоит из 3 структур и одной переменной. Подробное описание формата во вложении, просьба посмотреть его. У меня возникла...

Заполнение динамического массива структур из бинарного файла - C++
Здравствуйте! Нужна помощь в реализации вот такого алгоритма: предположим, что изначально мы создали динамический массив структур и...

Чтение массива структур из файла - C++
есть структура typedef struct { unsigned short codeContribution; unsigned short contributorCode; float amountContribution;...

Чтение из файла массива структур - C++
/* 4. Дана информация о семи студентах. Структура имеет вид: фамилия, имя, отчество и 4 оценки за экзамены. Вывести данные о...

Считывание структур из бинарного файла в динамический массив - C++
Доброго времени суток, форумчане, помогите пожалуйста, поделитесь знаниями или мне глаза откройте.. пишу программу(визуальное приложение)...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
nmcf
5319 / 4639 / 1551
Регистрация: 14.04.2014
Сообщений: 18,452
24.11.2016, 20:30 #2
И что здесь можно понять? Что такое tick?
0
pavlenko2k16
1 / 1 / 1
Регистрация: 24.09.2016
Сообщений: 131
Завершенные тесты: 1
24.11.2016, 20:33  [ТС] #3
C++
1
2
3
4
5
6
7
struct tick {
    char name[25];
    int day;
    int month;
    int year;
    int cost;
};
вот структура

Добавлено через 18 секунд
вот полный код, если интересует
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
#include <fstream>
#include <windows.h>
#include <iostream>
#include <cstdio>
 
using namespace std;
 
struct tick {
    char name[25];
    int day;
    int month;
    int year;
    int cost;
};
 
void Sort (fstream& buf, int num) {
    buf.seekg(0); 
    tick ticks[num];
    
    for (int i = 0; i < num; i++) {
    buf.read((char*)&ticks[i], sizeof(tick));
        cout << endl << ticks[i].name;
    }
    for (int i = 0; i < num; i++)
    for (int j = 0; j < (num - 1); j++) {
    if (ticks[j].name > ticks[j + 1].name)
    swap (ticks[j].name, ticks[j + 1].name);
    }
}
 
void zapolnenie () {
    ofstream out ("input.dat", ios_base::out | ios_base::binary | ios_base::app);
    
    int num;
    char cc[100];
    
    cout << "Введите количество тиков: ";;
    cin >> num;
    gets(cc);
    tick ticker[num];
    
    for (int i = 0; i < num; i++) {
        cout << endl << "Введите название тика: ";
        gets(ticker[i].name);
        for (;;) {
        cout << endl << "Введите дату (ДД ММ ГГГГ): "; 
        cin >> ticker[i].day; 
        cin >> ticker[i].month;
        cin >> ticker[i].year;
        gets(cc);
        if (ticker[i].day > 31 || ticker[i].day <= 0 || ticker[i].month <= 0 || ticker[i].month > 12 || ticker[i].year <= 0)
        cout << endl << "Повторите ввод!";
        else break;
    }
        cout << endl << "Введите стоимость: ";
        cin >> ticker[i].cost;
        gets(cc);
    }
    for (int i = 0; i < num; i++)
    out.write((char*)&ticker[i],sizeof(tick));
    out.close();
}
 
int main () {
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    setlocale (0, "");
 
    string otvet;
    char buf[100];
    int schet = 0;
    tick ticks[10];
    
    cout << endl << "Желаете добавить тикеры? ";
    for (;;) {
    cin >> otvet;
    if (otvet == "Y" || otvet == "y") {
        zapolnenie();
        break;
    }   
    else if (otvet == "N" || otvet == "n")
    break;
    else cout << endl << "Повторите ввод";
    }
    
    ifstream base ("input.dat", ios_base::in | ios_base::binary);
    for (int i = 0; !base.eof(); i++) {
     schet++;
    base.read((char*)&ticks[0], sizeof(tick));
    }
    
    base.clear(); 
    base.seekg(0); 
    schet = schet - 1;
    int step = schet/10; 
    
    fstream buf1("buf1.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < (schet - step * 9); i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf1.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf2("buf2.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf2.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf3("buf3.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf3.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf4("buf4.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf4.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf5("buf5.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf5.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf6("buf6.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf6.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf7("buf7.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf7.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf8("buf8.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf8.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf9("buf9.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf9.write((char*)&ticks[0],sizeof(tick));
    }
    fstream buf10("buf10.dat",  ios_base::out | ios_base::binary);
    for (int i = 0; i < step; i++) {
    base.read((char*)&ticks[0], sizeof(tick));
    buf10.write((char*)&ticks[0],sizeof(tick));
    }
    
    Sort (buf1, (schet - step * 9));
    Sort (buf2, step);
    Sort (buf3, step);
    Sort (buf4, step);
    Sort (buf5, step);
    Sort (buf6, step);
    Sort (buf7, step);
    Sort (buf8, step);
    Sort (buf9, step);
    Sort (buf10, step);
    
    buf1.close();
    buf2.close();
    buf3.close();
    buf4.close();
    buf5.close();
    buf6.close();
    buf7.close();
    buf8.close();
    buf9.close();
    buf10.close();
    remove("buf1.dat"); 
    remove("buf2.dat");
    remove("buf3.dat");
    remove("buf4.dat");
    remove("buf5.dat");
    remove("buf6.dat");
    remove("buf7.dat");
    remove("buf8.dat");
    remove("buf9.dat");
    remove("buf10.dat");
}
0
nmcf
5319 / 4639 / 1551
Регистрация: 14.04.2014
Сообщений: 18,452
24.11.2016, 20:50 #4
Конструкции типа
C++
1
tick ticks[num];
точно работают?

Подсчёт записей должен быть:
C++
1
while (base.read((char*)&ticks[0], sizeof(tick))) ++schet;
или
C++
1
2
3
base.seekg (0, base.end);
schet = base.tellg() / sizeof(tick);
base.seekg (0, base.beg);
И в Sort() добавь clear().
0
pavlenko2k16
1 / 1 / 1
Регистрация: 24.09.2016
Сообщений: 131
Завершенные тесты: 1
24.11.2016, 20:55  [ТС] #5
upd:: переместил запись файлов баф 1-10 в функцию

Добавлено через 4 минуты
Цитата Сообщение от nmcf Посмотреть сообщение
tick ticks[num];
работают, в мэйне все нормально отображало
0
nmcf
5319 / 4639 / 1551
Регистрация: 14.04.2014
Сообщений: 18,452
24.11.2016, 20:56 #6
В VS такое не работает.
0
pavlenko2k16
1 / 1 / 1
Регистрация: 24.09.2016
Сообщений: 131
Завершенные тесты: 1
24.11.2016, 21:16  [ТС] #7
Цитата Сообщение от nmcf Посмотреть сообщение
В VS такое не работает.
я в деве
ты говоришь о необходимости создавать динамический массив?

Добавлено через 6 минут
короче, психанул и сейчас буду делать функцию сортировки для каждого файла
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
void Sort1 (int num) {
    fstream buf1("buf1.dat", ios_base::in | ios_base::out | ios_base::binary);
    tick ticks[num];
    for (int i = 0; i < num; i++) {
    buf1.read((char*)&ticks[i], sizeof(tick));
        cout << endl << ticks[i].name;
    }
    for (int i = 0; i < num; i++)
    for (int j = 0; j < (num - 1); j++) {
    if (ticks[j].name > ticks[j + 1].name)
    swap (ticks[j].name, ticks[j + 1].name);
    }
}
или есть варианты проще?

Добавлено через 8 минут
+ появилась проблема, что сортирует по размеру. как по алфавиту сделать сортировку чаровских элементов?

Добавлено через 3 минуты
вопрос исчерпан
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.11.2016, 21:16
Привет! Вот еще темы с ответами:

Чтение бинарного файла - C++
Подскажите пожалуйста как можно правильно открыть бинарный файл не зная структуры? С чего мне начать? Вот пример:

Чтение бинарного файла - C++
как получить доступ к произвольному адресу файла? Нужно отправить файл через ком порт но не с 0 а с адреса 1а000 в цикле по 0х100 байт. с 0...

Чтение бинарного файла - C++
Привет! Необходима помощь в таком вопросе - Создал программу для хранения сведений о пользователях(типа такого: введите сведения: ...

Чтение из бинарного файла - C++
Всем приветы. Подскажите или помогите, пожалста. Есть вот такая штука: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
24.11.2016, 21:16
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru