wumu
2025-02-10 696f5b6779bd1f904c2497bb29a1cc991ab0477a
250210
5个文件已修改
60 ■■■■■ 已修改文件
clientmainwindow.cpp 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
getstocklist.cpp 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
getstocklist.h 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
historydata.cpp 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
historydata.h 11 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
clientmainwindow.cpp
@@ -52,4 +52,6 @@
    connect(m_regular,SIGNAL(getClosePriceSignal(QString)),m_getStockList,SLOT(getLastClosePrice(QString)));
    connect(m_getStockList,SIGNAL(sendClosePrice(QString,QString)),m_regular,SLOT(showClosePrice(QString,QString)));
    connect(m_getStockList,SIGNAL(sendCodeNames(QMap<QString,QString>&)),m_history,SLOT(putCodeNames(QMap<QString,QString>&)));
}
getstocklist.cpp
@@ -270,6 +270,9 @@
            m_model->appendRow(rowItems);
        }
    }
    // 发射信号
    emit sendCodeNames(m_codeNames);
}
getstocklist.h
@@ -45,6 +45,7 @@
    void sendChartData(QSplineSeries*);  // 曲线
    void sendInfoMess(QString); // 发送消息提示
    void sendClosePrice(QString,QString); // 发送最新的价格:名字、价格
    void sendCodeNames(QMap<QString, QString> &); // 给历史分析界面发送名字代号信息
private slots:
    void on_pushButton_get_clicked();
historydata.cpp
@@ -3,12 +3,15 @@
#include <QMessageBox>
#include <QDebug>
#include <QDateTime>
HistoryData::HistoryData(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::HistoryData)
{
    ui->setupUi(this);
    initMySQL(); // 初始化MySQL
}
HistoryData::~HistoryData()
@@ -16,11 +19,10 @@
    delete ui;
}
void HistoryData::on_pushButton_clicked()
void HistoryData::initMySQL()
{
    //添加一个数据库
      QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");    //括号内要写出数据库的类型
      db=QSqlDatabase::addDatabase("QMYSQL");    //括号内要写出数据库的类型
      //设置数据库
      db.setHostName("127.0.0.1"); //设置数据库的主机ip
      //设置数据库的用户名
@@ -36,3 +38,38 @@
          qDebug()<<"mysql conn ok";
      }
}
void HistoryData::on_pushButton_clicked()
{
    QSqlQuery que(db);
    QString sql = "select * from stock_day_info";
    if(que.exec(sql)){
        qDebug()<<"select ok";
    }else{
        qDebug()<<"select fail"<<que.lastError().text();
    }
}
void HistoryData::on_pushButton_update_clicked()
{
    // 把5000支股票挨个获取到,然后进行数据保存,存到表格中
    // 更新的时候,默认支持10年的数据查询
    QString time_tar=QString::number(QDateTime::currentMSecsSinceEpoch());
    QString dayCnt=QString::number(3000);
    QString type = "day"; // day week month
    for(auto code:m_codeNames.keys()){
        QString url = QString("https://stock.xueqiu.com/v5/stock/chart/kline.json?symbol=%1&begin=%2&period=%3&type=before&count=-%4&indicator=kline,pe,market_capital,ma").arg(code)
                .arg(time_tar).arg(type).arg(dayCnt);
        qDebug()<<"url:"<<url;
    }
}
void HistoryData::putCodeNames(QMap<QString, QString> &codeNames)
{
    m_codeNames = codeNames;
    qDebug()<<"size:"<<m_codeNames.size();
}
historydata.h
@@ -2,6 +2,7 @@
#define HISTORYDATA_H
#include <QMainWindow>
#include <QMap>
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
@@ -18,11 +19,21 @@
    explicit HistoryData(QWidget *parent = 0);
    ~HistoryData();
    void initMySQL();
private slots:
    void on_pushButton_clicked();
    void on_pushButton_update_clicked();
    void putCodeNames(QMap<QString,QString> &codeNames);
private:
    Ui::HistoryData *ui;
    QSqlDatabase db;
    QMap<QString,QString> m_codeNames; // 股票代号和名字
};
#endif // HISTORYDATA_H