Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 06.03.2018
Сообщений: 2
1

Чтение из csv файла с обработкой данных

14.03.2018, 10:35. Просмотров 1333. Ответов 1

Есть файл вида:
n,timestamp,latitude,longitude,speed
3439817,1519930809,54.9084609874777,56.076194964367,0.4

с записями о место положении транспортного средства. Так как прибор мониторинга неверное определяет низкую скорость, а спутниковое позиционирование не позволяет получать точные координаты, то в журнал попадает множество ложных записей, когда ТС на самом деле не двигается.
Требуется реализовать программу на С++ для удаления или усреднения ложных записей, при этом приоритет должен быть на сохранение максимально точной информации о маршруте.
Программа должна считать файл, обработать записи и сохранить результат в новом файле, алгоритм должен полагаться на поля latitude и longitude.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.03.2018, 10:35
Ответы с готовыми решениями:

Эффективное чтение файла CSV с обработкой ошибок
Цель - прочитать данные из CSV-файла с дальнейшей обработкой полученных данных. Начал с...

Чтение данных из файла report.csv
Доброго времени суток уважаемые форумчане! помогите пожалуйста... Есть файл формата .csv с...

Чтение файла CSV и чтение из Table View
Здравствуйте, задача считать столбцы и строки excel в TextEdit. Прошу помощи в реализиции. ...

Чтение из csv-файла
Добрый день. Мне нужно открыть в своей программе cs файл и найти там все методы - выделить их в...

1
2126 / 1664 / 828
Регистрация: 21.12.2010
Сообщений: 2,956
Записей в блоге: 11
14.03.2018, 15:16 2
Лучший ответ Сообщение было отмечено evil_angel2903 как решение

Решение

Т. е. нужно найти все строки с одинаковыми n и timestamp и усреднить в них latitude, longitude, speed ?

Добавлено через 1 час 21 минуту
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
#include <iostream>
#include <string>
#include <fstream>
#include <regex>
#include <cstdlib>
#include <vector>
#include <unordered_map>
#include <numeric>
#include <iomanip>
 
 
int main()
{
    std::fstream ifs("in.txt", std::ios::in), ofs("out.txt", std::ios::out);
    if (!ifs.is_open())
    {
        std::cerr << "Unable to open file\n";
        exit(1);
    }
    std::regex reg("(\\d+),(\\d+),([\\d.]+),([\\d.]+),([\\d.]+)");
    std::unordered_map<std::string, std::vector<std::vector<double>>> mp;
    std::string str;
    std::smatch mr;
    for (int i = 0; std::getline(ifs, str); ++i)
    {
        if (std::regex_match(str, mr, reg))
        {
            decltype(auto) mtx = mp[mr.str(1) + "," + mr.str(2)];
            if (mtx.size() == 0)
            {
                mtx.resize(3);
            }
            mtx[0].push_back(std::stod(mr.str(3)));
            mtx[1].push_back(std::stod(mr.str(4)));
            mtx[2].push_back(std::stod(mr.str(5)));
        }
        else
        {
            std::cerr << "regex_match failed on line " << std::to_string(i + 1) << "\n";
        }
    }
    //std::cout << mp.size() << std::endl;
    for (auto& pr : mp)
    {
        ofs << pr.first;
        for (int i = 0; i < pr.second.size(); ++i)
        {
            double aver = pr.second[i][0];
            if (pr.second[i].size() > 1)
            {
                aver = std::accumulate(pr.second[i].begin(), pr.second[i].end(), 0.) / pr.second[i].size();
            }
            ofs << ',' << std::setprecision(15) << aver;
        }
        ofs << '\n';
    }
 
 
    ifs.close();
    ofs.close();
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.03.2018, 15:16

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Чтение .csv файла
Считываю .csv файл. ifstream in(&quot;test.csv&quot;); string line, field; vector&lt;...

Чтение из файла csv
Здравствуйте! Читаю из файла csv данные, представленные в виде Поле1 Поле2 Поле3 Поле1 ...

Чтение CSV файла
Всем привет, не может кто-нибудь подсказать как прочитать таблицу в csv файле? Нужно каждую строку...

Чтение csv-файла с кириллицей
Здравствуйте. На странице сайта есть функционал чтения csv-файлов, которые пользователь может...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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