一个解析csv数据的小工具,所做项目中要查看脉冲图谱,经理就让我这个刚入职的小萌新写了个小程序。同事将csv格式的脉冲数据发给我,我的想法就是,将这些csv里的数据作为纵轴,x++为横轴,绘制出折线图,并将幅值整体偏低的脉冲加上个系数显示出来。

  因为用到了QChart,所以在.pro文件中先加语句 QT += charts

在ui界面中,加入了一个 Widget控件显示折线图(chart_view),在控件lineedit显示打开文件的路径和文件名,控件textedit显示打开的csv文本里的数据。点击按钮“打开文件”后,就可以选择要打开的文件,选好后,会显示出图谱和文件路径和csv中数据。点击“保存文件”把csv数据保存到本地为.txt文本。

  

代码:

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QFile>
#include <QFileDialog>
#include <QMessageBox>
#include <QtCharts/QChartView>//显示图表
#include <QtCharts/QLineSeries>//线系列
#include <QFileDialog>
#include <QDir>
#include <QString>
#include <QStringList>
#include <QDebug>
#include <QtCore/QTextStream>
#include <QtCore/QIODevice> MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
, ui(new Ui::MainWindow)
{
ui->setupUi(this); setWindowTitle("pluse脉冲解析");
setFixedSize(940,740);
connect(ui->btn_read, &QPushButton::clicked, this ,[=](){//打开文件 QT_CHARTS_USE_NAMESPACE QString FileName = QFileDialog::getOpenFileName(this,"打开文件","C:\\");
if(FileName.isEmpty() == true)
{
QMessageBox::warning(this,"warning","open file failed!");
return;
}
ui->lineEdit->setText(FileName); QList<QLineSeries *> m_series;
QLineSeries *series = new QLineSeries();
m_series.append(series); //设置线条名称
series->setName(QString("csv解析图谱")); //设置线条颜色,如果不设置会给默认颜色
series->setColor(QColor(255,0,255));
//设置是否线条可视
series->setVisible(true); //点标签是否可视
series->setPointLabelsVisible(true); //点标签颜色
series->setPointLabelsColor(QColor(255,255,255)); //点标签字体
series->setPointLabelsFont(QFont("微软雅黑")); //设置点标签显示格式
series->setPointLabelsFormat(" ");
//series->setPointLabelsFormat("(@xPoint,@yPoint)"); //是否切割边缘点标签,默认为true
series->setPointLabelsClipping(false); //设置点标签是否可视
//series->setPointsVisible(true); QFile file(FileName);
if(file.open(QIODevice::ReadOnly))
{
QTextStream stream(&file);
while(!file.atEnd())
{
QStringList list = stream.readAll().split('\n');
QListIterator<QString> li(list);
QString str = list.join(","); QString str1 = str.simplified(); //去除字符串前后的空白符,并用“ ”分开
str1.remove(QRegExp("\\s")); //去除所有字符串中出现的“ ”
QString str2 = str1.section(",",0,1023); //只取脉冲信号列表的前1024项
ui->textEdit->setText(str2); float buf;
int x = 1;
series->clear();
while(li.hasNext())
{ buf=li.next().toFloat();
if(x <= 1024)
{
series->append(x,buf * 32768);
x++;
}
else
break;
}
}
} QChart *chart = new QChart();
chart->setTheme(QChart::ChartThemeBlueCerulean);//设置系统主题
chart->setAnimationOptions(QChart::AllAnimations);//设置启用或禁用动画
chart->setLocalizeNumbers(true);//数字是否本地化
chart->addSeries(series);//添加系列到QChart上 chart->createDefaultAxes();//创建默认轴
chart->setTitle("脉冲图像");//设置标题
chart->setTitleBrush(QBrush(QColor(25,170,255)));//设置标题Brush
chart->setTitleFont(QFont("微软雅黑"));//设置标题字体 chart->legend()->setVisible(true);
chart->legend()->setAlignment(Qt::AlignBottom);//底部对齐
chart->legend()->setBackgroundVisible(true);//设置背景是否可视
chart->legend()->setLabelColor(QColor(255,128,255));//设置标签颜色
chart->legend()->setVisible(true);//设置是否可视
chart->legend()->setBorderColor(QColor(255,255,170,185));//设置边框颜色
QFont font = chart->legend()->font();
font.setItalic(!font.italic());
chart->legend()->setFont(font);//设置字体为斜体
font.setPointSizeF(12);
chart->legend()->setFont(font);//设置字体大小
chart->legend()->setFont(QFont("微软雅黑"));//设置字体类型 QChartView *chartView = new QChartView(chart);
QGridLayout *baselayout = new QGridLayout(); baselayout->addWidget(chartView,1,0);
chartView->setChart(chart);
ui->chart_view->setLayout(baselayout); connect(ui->btn_save,&QPushButton::clicked,this,[=](){//保存文件
QFile sfile("pluse.txt");
if(sfile.open(QFile::WriteOnly))
{
QTextStream out(&sfile);
//out<<ui->textEdit->setText()
out<<ui->textEdit->toPlainText()<<endl<<QObject::tr("");
QMessageBox::warning(this,"保存中...","文件保存成功!");
}
}); file.close(); }); } MainWindow::~MainWindow()
{
delete ui;
}

  目前还稍微有点小漏洞,就是不能在界面连续读取文件显示曲线图并保存,各位大佬要是有什么好办法,感谢分享呀!!

解析csv数据绘制曲线图的更多相关文章

  1. 解析csv数据导入mysql的方法

    mysql自己有个csv引擎,可以通过这个引擎来实现将csv中的数据导入到mysql数据库中,并且速度比通过php或是python写的批处理程序快的多. 具体的实现代码示例: 代码如下: load d ...

  2. Highcharts使用CSV格式数据绘制图表

    Highcharts使用CSV格式数据绘制图表 CSV(Comma-Separated Values,逗号分隔值文本格式)是採用逗号切割的纯文本数据.通常情况下.每一个数据之间使用逗号切割,几个相关数 ...

  3. Python 解析构建数据大杂烩 -- csv、xml、json、excel

    Python 可以通过各种库去解析我们常见的数据.其中 csv 文件以纯文本形式存储表格数据,以某字符作为分隔值,通常为逗号:xml 可拓展标记语言,很像超文本标记语言 Html ,但主要对文档和数据 ...

  4. .net解析csv(C#导表工具)

    前言 解析Excel有知名的NPOI库,(Java语言是POI),但是NPOI是不支持解析csv的. csv本质上也是文本文件,可以进行差异对比,更利于解决冲突. 本文对解析csv的几个.net的开源 ...

  5. Qt解析CSV文件

    最近需要解析Excel文件,于是顺带写了解析CSV的代码 定义数据类型LX::Sheet #ifndef LX_H #define LX_H #include <QString> #inc ...

  6. pgloader 学习(六) 加载csv 数据

    关于加载的配置参数都是使用comand file command file 参考格式 LOAD CSV FROM 'GeoLiteCity-Blocks.csv' WITH ENCODING iso- ...

  7. 分析Python中解析构建数据知识

    分析Python中解析构建数据知识 Python 可以通过各种库去解析我们常见的数据.其中 csv 文件以纯文本形式存储表格数据,以某字符作为分隔值,通常为逗号:xml 可拓展标记语言,很像超文本标记 ...

  8. 技术干货:Python解析CSV

    1. 什么是CSV CSV(Commma-Separated Value)是都好分隔符,其文件以纯文本形式存储表格数据(数字和文本). 案例: 2. 为什么要使用CSV 与专有的二进制文件格式截然不同 ...

  9. java opencsv解析csv文件

    记一次使用opencsv解析csv文件时碰到的坑 最近在开发过程中需要解析csv文件,公司用的解析工具是opencsv,在根据opencsv的官方文档去解析时发现csv文件中含有繁体字,使用其自带的C ...

随机推荐

  1. Mybatis中多表联查,查询出来的字段出现重名,造成数据异常的解决方法!

    在做一对多出现的问题,引发的思考:当数据库表中,主表的主键id和明细表的中的字段名相同时怎么办?Mybatis进行自动映射赋值的时候会不会出现异常?                      注意:M ...

  2. redis>lua脚本

    String lua="local num=redis.call('incr',KEYS[1])\n"+"if tonumber(num)==1 then\n" ...

  3. OKR工作法读后感

    <OKR工作法>把管理思想融入到一则创业故事中,故事细节经过了精心的设计,融入了管理智慧和踩坑填坑经验,每个细节都以小见大,耐人寻味.一千个读者,就有一千个哈姆雷特. 所以这次我不去点评大 ...

  4. 接口测试进阶接口脚本使用--apipost(预/后执行脚本)

    预执行脚本的作用时间 预执行脚本是一个请求发送前执行的脚本. 预执行脚本的作用 预执行脚本可以完成以下作用: 编写JS函数等实现复杂计算: 变量的打印 定义.获取.删除.清空环境变量 定义.获取.删除 ...

  5. vsftpd 参数说明

    2021-07-28 该文章为转载文章,非原创 参数作用# 是否允许匿名访问 [ 12行 ]anonymous_enable=[YES|NO]# 是否允许本地用户访问( /etc/passwd中的用户 ...

  6. 使用vbs调用excel中的宏

    使用vbs打开excel文件,并且传递参数调用excel中的macro,自动化完成excel文件的制作. Set oExcel = createobject("Excel.Applicati ...

  7. 如何实现 Android 短视频跨页面的流畅续播?

    在一切皆可视频化的今天,短视频内容作为移动端产品新的促活点,受到了越来越多的重视与投入,同时短视频也是增加用户粘性.增加用户停留时长的一把利器.那么如何快速实现移动端短视频功能呢?前两篇我们介绍了盒马 ...

  8. 这款打怪升级的小游戏,7 年前出生于 GitHub 社区,如今在谷歌商店有 8 万人打了满分

    今天我在 GitHub 摸鱼寻找新的"目标"时,发现了一个开源项目是 RougeLike 类的角色扮演游戏「破碎版像素地牢」(Shattered Pixel Dungeon)类似魔 ...

  9. openswan中的in_struct和out_struct函数

    openswan中的in_struct和out_struct函数 文章目录 openswan中的in_struct和out_struct函数 1. 花絮 2. in_struct代码实现分析 3. 它 ...

  10. Delphi使用Zxing创建二维码

    效果 DelphiZXingQRCode下载地址:https://www.debenu.com/open-source/delphizxingqrcode/ 为了调用方便unit DelphiZXIn ...