和处理。其中我用正则表达式过滤的一些无用标签。
代码是经过修改的,尽量通用化,理论上复制下来就能用。宏QTHQ_BASESHARED_EXPORT 删掉即可,原本是用于制作成dll的选项的,具体可以参考我的其它文章。
Qt制作dll(带ui)并调用,兼容32位和64位_redeclared without dllimport_大橘的博客-CSDN博客
hq_base_db_grid_excel.h:
/**************************************************************************************************
** File name: hq_base_db_grid_excel.h (HQ_Base_DB_Grid_Excel)
** Created by: Henrick.Nie at 2023-7-10
** Used for: Import/export the grid data from/to the excel file.
**************************************************************************************************/
#ifndef HQ_BASE_DB_GRID_EXCEL_H
#define HQ_BASE_DB_GRID_EXCEL_H
#include "qt-hq_base_global.h"
#include
#include
#include
#include
#include
#include
#include
#include "hq_base_db_grid.h"
class QTHQ_BASESHARED_EXPORT HQ_Base_DB_Grid_Excel
{
public:
static bool f_SaveToExcel(QTableWidget *oGrid,
const bool &bAskBeforeDoing, const bool &bAskBeforeOpenning, QString *sFilePath = nullptr,
QString *sErr = nullptr, const QString &sSheetName = QString());
static bool f_SaveToExcel(const QString &sExcelHtmlModel, QTableWidget *oGrid,
const bool &bAskBeforeDoing, const bool &bAskBeforeOpenning, QString *sFilePath = nullptr,
QString *sErr = nullptr, const QString &sSheetName = QString());
static bool f_GetFromExcel_AsXML(QString &sXML, QString *sErr = nullptr);
static bool f_GetFromExcel(const QString &sModel, QJsonArray &oArrRows, const bool &bFirstRowIsHeader = false, QString *sErr = nullptr);
static bool f_GetFromExcel(QTableWidget *oGrid, const bool &bFirstRowIsHeader = false, QString *sErr = nullptr);
static bool f_SetFirstRowToHeader(QTableWidget *oGrid, const bool &bSetHeader, QString *sErr = nullptr);
private:
static bool f_Grid_GetDataAsHtml(QTableWidget *oGrid, QString &sTableHtml, QString *sErr = nullptr);
static QString f_Grid_GetAlignByEnum(const int &iAlign);
static bool f_Excel_GetDataAsHtml(QString &sTableHtml, QString *sErr = nullptr);
};
#endif // HQ_BASE_DB_GRID_EXCEL_H
hq_base_db_grid_excel.cpp:
#include "hq_base_db_grid_excel.h"
/**================================================================================================
** Converts the grid data as the html table string, output it in the parameter 'sTableHtml'.
** Returns true on successed, otherwise returns false.
** ---------------------------------
** Format:
**
**
**
**
**
**
**
** f1
** f2
** f3
** f4
**
**
** 1
** 2
** 3
** 4
**
**
** a
** b
** c
** d
**
**
** cwd
** qwe
** xcz
** excz
**
**
**
**===============================================================================================*/
bool HQ_Base_DB_Grid_Excel::f_Grid_GetDataAsHtml(QTableWidget *oGrid, QString &sTableHtml, QString *sErr)
{
sTableHtml.clear();
if (nullptr == oGrid)
{
HQ_Base::f_Pointer_SetValue(sErr, QString("The grid is nullptr."));
return false;
}
//Indent
QString sTable_col, sTable_Rows_tr, sIndent_table = " ", sIndent_col = " ", sIndent_tr = " ", sIndent_td = " ";
//Headers and col info( )
sTable_Rows_tr.append(sIndent_tr + "\n");
QString sHeader_td;
for (int iCol = 0; iCol < oGrid->columnCount(); ++iCol)
{
//width
QString sCol_Width = QString::number(oGrid->columnWidth(iCol));
//align
QTableWidgetItem *item = oGrid->horizontalHeaderItem(iCol);
int iAlign = (nullptr == item) ? 0 : item->textAlignment();
QString sCol_Align = f_Grid_GetAlignByEnum(iAlign);
sTable_col.append(sIndent_col + " \n");
//header row
sHeader_td.append(sIndent_td + "" + oGrid->horizontalHeaderItem(iCol)->text() + " \n");
}
sTable_Rows_tr.append(sHeader_td);
sTable_Rows_tr.append(sIndent_tr + " \n");
//data( )
for (int iRow = 0; iRow < oGrid->rowCount(); ++iRow)
{
sTable_Rows_tr.append(sIndent_tr + "\n");
QString sRows_td;
for (int iCol = 0; iCol < oGrid->columnCount(); ++iCol)
{
QTableWidgetItem *item = oGrid->item(iRow, iCol);
QString sText;
if (nullptr != item)
{
sText = item->text();
}
sRows_td.append(sIndent_td + "" + sText + " \n");
}
sTable_Rows_tr.append(sRows_td);
sTable_Rows_tr.append(sIndent_tr + " \n");
}
//table
sTableHtml.append(sIndent_table + "\n");
sTableHtml.append(sTable_col);
sTableHtml.append(sTable_Rows_tr);
sTableHtml.append(sIndent_table + "
\n");
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
QString HQ_Base_DB_Grid_Excel::f_Grid_GetAlignByEnum(const int &iAlign)
{
quint16 iHAlign = iAlign | 0x000F;
QString sAlign;
switch (iHAlign) {
case 1:
sAlign = "left";
break;
case 2:
sAlign = "right";
break;
case 4:
sAlign = "center";
break;
default:
break;
}
return sAlign;
}
/**================================================================================================
** Save the grid data to excel.
**===============================================================================================*/
bool HQ_Base_DB_Grid_Excel::f_SaveToExcel(QTableWidget *oGrid,
const bool &bAskBeforeDoing, const bool &bAskBeforeOpenning,
QString *sFilePath, QString *sErr, const QString &sSheetName)
{
try
{
//Get the model.
QString sFile = "excel_html.md";
QFile f(sFile);
if (!f.exists())
{
throw QString("Can not find the model file.");
}
if (!f.open(QIODevice::ReadOnly|QIODevice::Text))
{
if (f.isOpen())
{
f.close();
}
throw QString("The model file openning failed.");
}
QString sExcelHtml = f.readAll();
if (f.isOpen())
{
f.close();
}
return f_SaveToExcel(sExcelHtml, oGrid, bAskBeforeDoing, bAskBeforeOpenning, sFilePath, sErr, sSheetName);
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
bool HQ_Base_DB_Grid_Excel::f_SaveToExcel(const QString &sExcelHtmlModel, QTableWidget *oGrid,
const bool &bAskBeforeDoing, const bool &bAskBeforeOpenning,
QString *sFilePath, QString *sErr, const QString &sSheetName)
{
try
{
HQ_Base::f_Pointer_SetValue(sFilePath, QString());
HQ_Base::f_Pointer_SetValue(sErr, QString());
QString sExcelHtml = sExcelHtmlModel;
if (sExcelHtml.isEmpty())
{
throw QString("The excel model lost.");
}
if (nullptr == oGrid)
{
throw QString("The grid does not exist.");
}
QString sMsg;
//Ask user before doing.
if (bAskBeforeDoing)
{
sMsg = "Export the grid data to the excel. Continue?";
if(QMessageBox::question(nullptr, "", sMsg, QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes) != QMessageBox::Yes)
{
return false;
}
}
//Select the saving path.
QString sFile_Saved = QFileDialog::getSaveFileName(nullptr, "Select the saving path.",
QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation),
"Excel (*.xlsx);;Excel 97-2003 (*.xls)");
if (sFile_Saved.isEmpty())
{
return false;//If the user canceled, do nothing.
}
//If the target file is not writable.
QFile f_Save(sFile_Saved);
if (f_Save.isOpen() || !f_Save.open(QIODevice::WriteOnly|QIODevice::Text))
{
if (f_Save.isOpen())
{
f_Save.close();
}
throw QString("The target file is using. Perhaps it is already openned by an other program.");
}
//Sheet name.
if (!sSheetName.isEmpty())
{
sExcelHtml.replace(QRegularExpression("(?<=)[\\s\\S]*(?= )"), sSheetName);
}
//Html_table.
QString sTableHtml;
if (!f_Grid_GetDataAsHtml(oGrid, sTableHtml, sErr))
{
return false;
}
sExcelHtml.replace(QRegularExpression(""), sTableHtml);
//Save to file.
qint64 i = f_Save.write(sExcelHtml.toStdString().c_str());
if (f_Save.isOpen())
{
f_Save.close();
}
if (i < 0)
{
throw QString("The file writting failed.");
}
//Ask before openning.
if (bAskBeforeOpenning)
{
sMsg = "The excel file exporting successed, open it?\n";
if(QMessageBox::question(nullptr, "", sMsg + sFile_Saved, QMessageBox::Yes|QMessageBox::No) == QMessageBox::Yes)
{
//Open the file.
QDesktopServices::openUrl(QUrl("file:///" + QDir::toNativeSeparators(sFile_Saved)));
}
}
HQ_Base::f_Pointer_SetValue(sFilePath, sFile_Saved);
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sFilePath, QString());
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
/**================================================================================================
** Import the excel data to the html string, and output into the parameter 'sTableHtml'.
**===============================================================================================*/
bool HQ_Base_DB_Grid_Excel::f_Excel_GetDataAsHtml(QString &sTableHtml, QString *sErr)
{
try
{
sTableHtml.clear();
HQ_Base::f_Pointer_SetValue(sErr, QString());
QString sFileName = QFileDialog::getOpenFileName(nullptr, "Select the saving path.",
QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation),
"Excel (*.xlsx);;Excel 97-2003 (*.xls)");
if (sFileName.isEmpty())
{
return false;//If the user canceled, do nothing.
}
QFile f(sFileName);
if (!f.open(QIODevice::ReadOnly|QIODevice::Text))
{
if (f.isOpen())
{
f.close();
}
throw QString("The excel file openning failed.");
}
QString sExcelHtml = f.readAll();
if (f.isOpen())
{
f.close();
}
QRegularExpressionMatch match = QRegularExpression("").match(sExcelHtml);
if (!match.hasMatch())
{
throw QString("The excel file format is error.");
}
sTableHtml = match.captured();
sTableHtml.replace(QRegularExpression("\\bx:[^ <>]+\\b"), "");//remove 'x:str' or 'x:num', 'x:...'.
sTableHtml.replace(QRegularExpression(" ]*/>"), "");//remove ''.
sTableHtml.replace(QRegularExpression("]*\\]>[\\S\\s]*"), "");//remove '...'.
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
/**================================================================================================
** Import the excel data to the xml string, and output into the parameter 'sXML'.
**===============================================================================================*/
bool HQ_Base_DB_Grid_Excel::f_GetFromExcel_AsXML(QString &sXML, QString *sErr)
{
try
{
sXML.clear();
//Import the excel data into the variable 'sTableHtml' as html.
QString sTableHtml;
if (!f_Excel_GetDataAsHtml(sTableHtml, sErr))
{
return false;
}
QDomDocument doc;
QString sErrMsg;
int iRow, iCol;
if (!doc.setContent(sTableHtml, &sErrMsg, &iRow, &iCol))
{
throw sErrMsg + ", the position in excel file is: row = " + QString::number(iRow)
+ ", col = " + QString::number(iCol) + ".";
}
//Get '', and remove the nodes that is not ' '.
QDomNode node_Table = doc.firstChild();
int i = 0;
while (i < node_Table.childNodes().size())
{
QDomNode node = node_Table.childNodes().at(i);
if (node.nodeName() == "tr")
{
++i;
}
else
{
node_Table.removeChild(node);
}
}
doc.replaceChild(node_Table, doc.firstChild());
sXML = doc.toString();
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
/**================================================================================================
** Import the data from the excel file to the json array by the given model.
**===============================================================================================*/
bool HQ_Base_DB_Grid_Excel::f_GetFromExcel(const QString &sModel, QJsonArray &oArrRows, const bool &bFirstRowIsHeader, QString *sErr)
{
try
{
oArrRows = QJsonArray();
//Import the excel data into the variable 'sXML' as the xml string.
QString sXML;
if (!f_GetFromExcel_AsXML(sXML, sErr))
{
return false;
}
QDomDocument doc;
QString sErrMsg;
int iRow, iCol;
if (!doc.setContent(sXML, &sErrMsg, &iRow, &iCol))
{
throw sErrMsg + ", the position in excel file is: row = " + QString::number(iRow)
+ ", col = " + QString::number(iCol) + ".";
}
QDomNode node_Table = doc.firstChild();
//Get the cols info from the model.
QJsonObject oJsonModel = HQ_Base::f_Json_StringToJsonObj(sModel);
if (oJsonModel.isEmpty())
{
throw QString("The given model string can not convert to json object.");
}
QStringList sColList = oJsonModel.value("Cols_Visible").toString().split("|", QString::SkipEmptyParts);
//If it has the header, remove the first node.
if (bFirstRowIsHeader)
{
node_Table.removeChild(node_Table.firstChild());
}
//tr (rows)
int iTrCount = node_Table.childNodes().size();
for (int i_tr = 0; i_tr < iTrCount; ++i_tr)
{
QDomNode node_tr = node_Table.childNodes().at(i_tr);
QJsonObject oJsonRow;
//td (cells)
for (int iCol = 0; iCol < sColList.size(); ++iCol)
{
QString sColName = sColList.at(iCol);
QString sValue;
if (iCol < node_tr.childNodes().size())
{
QDomElement el_td = node_tr.childNodes().at(iCol).toElement();
sValue = el_td.text();
}
oJsonRow.insert(sColName, sValue);
}
oArrRows.append(oJsonRow);
}
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
/**================================================================================================
** Import the data from the excel file to the grid.
**===============================================================================================*/
bool HQ_Base_DB_Grid_Excel::f_GetFromExcel(QTableWidget *oGrid, const bool &bFirstRowIsHeader, QString *sErr)
{
try
{
//Import the excel data into the variable 'sXML' as the xml string.
QString sXML;
if (!f_GetFromExcel_AsXML(sXML, sErr))
{
return false;
}
QDomDocument doc;
QString sErrMsg;
int iRow, iCol;
if (!doc.setContent(sXML, &sErrMsg, &iRow, &iCol))
{
throw sErrMsg + ", the position in excel file is: row = " + QString::number(iRow)
+ ", col = " + QString::number(iCol) + ".";
}
QDomNode node_Table = doc.firstChild();
//tr
int iTrCount = node_Table.childNodes().size();
int iRowCount = bFirstRowIsHeader ? iTrCount - 1 : iTrCount;
oGrid->setRowCount(iRowCount);
for (int i_tr = 0; i_tr < iTrCount; ++i_tr)
{
QDomNode node_tr = node_Table.childNodes().at(i_tr);
//td
if (oGrid->columnCount() < node_tr.childNodes().size())
{
oGrid->setColumnCount(node_tr.childNodes().size());
}
for (int i_td = 0; i_td < node_tr.childNodes().size(); ++i_td)
{
QDomElement el_td = node_tr.childNodes().at(i_td).toElement();
QTableWidgetItem *item = new QTableWidgetItem(el_td.text());
if (bFirstRowIsHeader)
{
if (i_tr == 0)
{
oGrid->setHorizontalHeaderItem(i_td, item);
}
else
{
oGrid->setItem(i_tr - 1, i_td, item);
}
}
else
{
oGrid->setItem(i_tr, i_td, item);
}
}
}
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
bool HQ_Base_DB_Grid_Excel::f_SetFirstRowToHeader(QTableWidget *oGrid, const bool &bSetHeader, QString *sErr)
{
try
{
//made header
if (bSetHeader)
{
if (oGrid->rowCount() < 1)
{
throw QString("Operation canceled. For the grid row count is lesser than 1.");
}
for (int iCol = 0; iCol < oGrid->columnCount(); ++iCol)
{
QTableWidgetItem *item = oGrid->horizontalHeaderItem(iCol);
if (nullptr == item)
{
item = new QTableWidgetItem;
}
QString sFirstRowCellText;
if (nullptr != oGrid->item(0, iCol))
{
sFirstRowCellText = oGrid->item(0, iCol)->text();
}
item->setText(sFirstRowCellText);
oGrid->setHorizontalHeaderItem(iCol, item);
delete oGrid->item(0, iCol);
}
oGrid->removeRow(0);
}
//remove header
else
{
oGrid->insertRow(0);
for (int iCol = 0; iCol < oGrid->columnCount(); ++iCol)
{
QTableWidgetItem *item = oGrid->horizontalHeaderItem(iCol);
if (nullptr == item)
{
item = new QTableWidgetItem;
}
QString sText = item->text();
item->setText(QString::number(iCol));
oGrid->setHorizontalHeaderItem(iCol, item);
item = new QTableWidgetItem(sText);
oGrid->setItem(0, iCol, item);
}
}
HQ_Base::f_Pointer_SetValue(sErr, QString());
return true;
}
catch (QString sExceptionMsg)
{
HQ_Base::f_Pointer_SetValue(sErr, sExceptionMsg);
return false;
}
}
代码是我又改了一版通用的。因为之前我的电子表格QTabWidget是自己包装过的,可以根据json模板自动加载表头和数据,并处理对齐,用起来更方便。
而我想把excel功能改得让它更通用,不依赖于我包装了类库。其它就没什么了。下面是我的程序运行情况。
4.运行测试:
首先在界面上添加一个按钮,在它的槽函数中写:
//导出excel:
QString sErr;
if (!HQ_Base_DB_Grid_Excel::f_SaveToExcel(ui->oGridMain, false, true, nullptr, &sErr, "SingleGrid"))
{
if (!sErr.isEmpty())
{
QMessageBox::warning(this, "Exporting failed", sErr, QMessageBox::Ok, QMessageBox::NoButton);
}
}
/* 这里oGridMain是我自己命名的,就是一个QTableWidget。
* 后面参数作用:执行前不询问,执行后询问是否要打开exce文件,
* excel文件路径传入nullptr不获取到外部程序,sheet1表单显示名称设置为“SingleGrid”。
*/
//导入excel:
QString sErr;
QString sModel = ui->oGridMain->f_GetModel(&sErr);
QJsonArray oArrRows;
if (!HQ_Base_DB_Grid_Excel::f_GetFromExcel(sModel, oArrRows, false, &sErr))
{
if (!sErr.isEmpty())
{
QMessageBox::warning(this, "Importing failed", sErr, QMessageBox::Ok, QMessageBox::NoButton);
}
return;
}
ui->oGridMain->addRow(oArrRows);
/* 这里oGridMain是用了我自己做的一个表格类。可以自动根据模板加载表头和数据。
* 如果读者想直接用通用的QTableWidget,可以挑选f_GetFromExcel的其它重载。
*/
很简单,主要就调用f_GetFromExcel函数这一行。然后效果就出来了。
代码中又尝试做了excel导入功能,道理类似。就不再贴图了。当然要注意,这种方式既然是基于文本替换实现的,那导入时对文件也有要求,把excel另存为html,或者粘贴到一个html格式的excel文件中。这样才可以被代码解析。
这里我做了取舍,不想依赖office或wps环境,导入时就多了这一步。除非像开发一个wps一样,能够彻底独立操作excel。
上述方法仅仅是一个思路。网上axobject和openxml的方式都有代码,就是不喜欢ax模式,openxml的代码,qt在处理zip时用到了私有库,想去掉警告还挺麻烦的。因为我想实现一个真正没有任何强依赖,又好用的东西。当然目前我做的还差得远。
5.总结:
开头说过,这种方法不完美,但不仅仅是因为上述原因。亲测,wps支持较好,office不行,毕竟这种方法太粗暴。网上看过openxml相关代码,貌似都在vs环境下使用。目前还没想到更好方法,也不想浪费过多时间。
各位高手可以讨论一下,如果有更好的方式,记得交流一下。
本文完。
你可能感兴趣的:(qt/c++,excel,qt,c++)
c++ 的iostream 和 c++的stdio的区别和联系
黄卷青灯77
c++ 算法 开发语言 iostream stdio
在C++中,iostream和C语言的stdio.h都是用于处理输入输出的库,但它们在设计、用法和功能上有许多不同。以下是两者的区别和联系:区别1.编程风格iostream(C++风格):C++标准库中的输入输出流类库,支持面向对象的输入输出操作。典型用法是cin(输入)和cout(输出),使用>操作符来处理数据。更加类型安全,支持用户自定义类型的输入输出。#includeintmain(){in
Linux下QT开发的动态库界面弹出操作(SDL2)
13jjyao
QT类 qt 开发语言 sdl2 linux
需求:操作系统为linux,开发框架为qt,做成需带界面的qt动态库,调用方为java等非qt程序难点:调用方为java等非qt程序,也就是说调用方肯定不带QApplication::exec(),缺少了这个,QTimer等事件和QT创建的窗口将不能弹出(包括opencv也是不能弹出);这与qt调用本身qt库是有本质的区别的思路:1.调用方缺QApplication::exec(),那么我们在接口
python os.environ_python os.environ 读取和设置环境变量
weixin_39605414
python os.environ
>>>importos>>>os.environ.keys()['LC_NUMERIC','GOPATH','GOROOT','GOBIN','LESSOPEN','SSH_CLIENT','LOGNAME','USER','HOME','LC_PAPER','PATH','DISPLAY','LANG','TERM','SHELL','J2REDIR','LC_MONETARY','QT_QPA
【JS】执行时长(100分) |思路参考+代码解析(C++)
l939035548
JS 算法 数据结构 c++
题目为了充分发挥GPU算力,需要尽可能多的将任务交给GPU执行,现在有一个任务数组,数组元素表示在这1秒内新增的任务个数且每秒都有新增任务。假设GPU最多一次执行n个任务,一次执行耗时1秒,在保证GPU不空闲情况下,最少需要多长时间执行完成。题目输入第一个参数为GPU一次最多执行的任务个数,取值范围[1,10000]第二个参数为任务数组长度,取值范围[1,10000]第三个参数为任务数组,数字范围
pyecharts——绘制柱形图折线图
2224070247
信息可视化 python java 数据可视化
一、pyecharts概述自2013年6月百度EFE(ExcellentFrontEnd)数据可视化团队研发的ECharts1.0发布到GitHub网站以来,ECharts一直备受业界权威的关注并获得广泛好评,成为目前成熟且流行的数据可视化图表工具,被应用到诸多数据可视化的开发领域。Python作为数据分析领域最受欢迎的语言,也加入ECharts的使用行列,并研发出方便Python开发者使用的数据
基于CODESYS的多轴运动控制程序框架:逻辑与运动控制分离,快速开发灵活操作
GPJnCrbBdl
python 开发语言
基于codesys开发的多轴运动控制程序框架,将逻辑与运动控制分离,将单轴控制封装成功能块,对该功能块的操作包含了所有的单轴控制(归零、点动、相对定位、绝对定位、设置当前位置、伺服模式切换等等)。程序框架由主程序按照状态调用分归零模式、手动模式、自动模式、故障模式,程序状态的跳转都已完成,只需要根据不同的工艺要求完成所需的动作即可。变量的声明、地址的规划都严格按照C++的标准定义,能帮助开发者快速
C++ | Leetcode C++题解之第409题最长回文串
Ddddddd_158
经验分享 C++ Leetcode 题解
题目:题解:classSolution{public:intlongestPalindrome(strings){unordered_mapcount;intans=0;for(charc:s)++count[c];for(autop:count){intv=p.second;ans+=v/2*2;if(v%2==1andans%2==0)++ans;}returnans;}};
C++菜鸟教程 - 从入门到精通 第二节
DreamByte
c++
一.上节课的补充(数据类型)1.前言继上节课,我们主要讲解了输入,输出和运算符,我们现在来补充一下数据类型的知识上节课遗漏了这个知识点,非常的抱歉顺便说一下,博主要上高中了,更新会慢,2-4周更新一次对了,正好赶上中秋节,小编跟大家说一句:中秋节快乐!2.int类型上节课,我们其实只用了int类型int类型,是整数类型,它们存贮的是整数,不能存小数(浮点数)定义变量的方式很简单inta;//定义一
《Python数据分析实战终极指南》
xjt921122
python 数据分析 开发语言
对于分析师来说,大家在学习Python数据分析的路上,多多少少都遇到过很多大坑**,有关于技能和思维的**:Excel已经没办法处理现有的数据量了,应该学Python吗?找了一大堆Python和Pandas的资料来学习,为什么自己动手就懵了?跟着比赛类公开数据分析案例练了很久,为什么当自己面对数据需求还是只会数据处理而没有分析思路?学了对比、细分、聚类分析,也会用PEST、波特五力这类分析法,为啥
Java面试题精选:消息队列(二)
芒果不是芒
Java面试题精选 java kafka
一、Kafka的特性1.消息持久化:消息存储在磁盘,所以消息不会丢失2.高吞吐量:可以轻松实现单机百万级别的并发3.扩展性:扩展性强,还是动态扩展4.多客户端支持:支持多种语言(Java、C、C++、GO、)5.KafkaStreams(一个天生的流处理):在双十一或者销售大屏就会用到这种流处理。使用KafkaStreams可以快速的把销售额统计出来6.安全机制:Kafka进行生产或者消费的时候会
esp32开发快速入门 8 : MQTT 的快速入门,基于esp32实现MQTT通信
z755924843
ESP32开发快速入门 服务器 网络 运维
MQTT介绍简介MQTT(MessageQueuingTelemetryTransport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的"轻量级"通讯协议,该协议构建于TCP/IP协议上,由IBM在1999年发布。MQTT最大优点在于,可以以极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。作为一种低开销、低带宽占用的即时通讯协议,使其在物联
C++ lambda闭包消除类成员变量
barbyQAQ
c++ c++ java 算法
原文链接:https://blog.csdn.net/qq_51470638/article/details/142151502一、背景在面向对象编程时,常常要添加类成员变量。然而类成员一旦多了之后,也会带来干扰。拿到一个类,一看成员变量好几十个,就问你怕不怕?二、解决思路可以借助函数式编程思想,来消除一些不必要的类成员变量。三、实例举个例子:classClassA{public:...intfu
基于STM32与Qt的自动平衡机器人:从控制到人机交互的的详细设计流程
极客小张
stm32 qt 机器人 物联网 人机交互 毕业设计 c语言
一、项目概述目标和用途本项目旨在开发一款基于STM32控制的自动平衡机器人,结合步进电机和陀螺仪传感器,实现对平衡机器人的精确控制。该机器人可以用于教育、科研、娱乐等多个领域,帮助用户了解自动控制、机器人运动学等相关知识。技术栈关键词STM32单片机步进电机陀螺仪传感器AD采集电路Qt人机界面实时数据监控二、系统架构系统架构设计本项目的系统架构设计包括以下主要组件:控制单元:STM32单片机传感器
2021 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级C++语言试题 (第三大题:完善程序 代码)
mmz1207
c++ csp
最近有一段时间没更新了,在准备CSP考试,请大家见谅。(1)有n个人围成一个圈,依次标号0到n-1。从0号开始,依次0,1,0,1...交替报数,报到一的人离开,直至圈中剩最后一个人。求最后剩下的人的编号。#includeusingnamespacestd;intf[1000010];intmain(){intn;cin>>n;inti=0,cnt=0,p=0;while(cnt#includeu
《 C++ 修炼全景指南:九 》打破编程瓶颈!掌握二叉搜索树的高效实现与技巧
Lenyiin
C++ 修炼全景指南 技术指南 c++ 算法 stl
摘要本文详细探讨了二叉搜索树(BinarySearchTree,BST)的核心概念和技术细节,包括插入、查找、删除、遍历等基本操作,并结合实际代码演示了如何实现这些功能。文章深入分析了二叉搜索树的性能优势及其时间复杂度,同时介绍了前驱、后继的查找方法等高级功能。通过自定义实现的二叉搜索树类,读者能够掌握其实际应用,此外,文章还建议进一步扩展为平衡树(如AVL树、红黑树)以优化极端情况下的性能退化。
ESP32-C3入门教程 网络篇⑩——基于esp_https_ota和MQTT实现开机主动升级和被动触发升级的OTA功能
小康师兄
ESP32-C3入门教程 https 服务器 esp32 OTA MQTT
文章目录一、前言二、软件流程三、部分源码四、运行演示一、前言本文基于VSCodeIDE进行编程、编译、下载、运行等操作基础入门章节请查阅:ESP32-C3入门教程基础篇①——基于VSCode构建HelloWorld教程目录大纲请查阅:ESP32-C3入门教程——导读ESP32-C3入门教程网络篇⑨——基于esp_https_ota实现史上最简单的ESP32OTA远程固件升级功能二、软件流程
20个新手学习c++必会的程序 输出*三角形、杨辉三角等(附代码)
X_StarX
c++ 学习 算法 大学生 开发语言 数据结构
示例1:HelloWorld#includeusingnamespacestd;intmain(){coutusingnamespacestd;intmain(){inta=5;intb=10;intsum=a+b;coutusingnamespacestd;intfactorial(intn){if(nusingnamespacestd;voidprintFibonacci(intn){intt
C++八股
Petrichorzncu
八股总结 c++ 开发语言
这里写目录标题C++内存管理C++的构造函数,复制构造函数,和析构函数深复制与浅复制:构造函数和析构函数哪个能写成虚函数,为什么?C++数据结构内存排列结构体和类占用的内存:==虚函数和虚表的原理==虚函数虚表(Vtable)虚函数和虚表的实现细节==内存泄漏==指针的工作原理函数的传值和传址new和delete与malloc和freeC++内存区域划分C++11新特性C++常见新特性==智能指针
【2022 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级 C++语言试题及解析】
汉子萌萌哒
CCF noi 算法 数据结构 c++
一、单项选择题(共15题,每题2分,共计30分;每题有且仅有一个正确选项)1.以下哪种功能没有涉及C++语言的面向对象特性支持:()。A.C++中调用printf函数B.C++中调用用户定义的类成员函数C.C++中构造一个class或structD.C++中构造来源于同一基类的多个派生类题目解析【解析】正确答案:AC++基础知识,面向对象和类有关,类又涉及父类、子类、继承、派生等关系,printf
《 C++ 修炼全景指南:十 》自平衡的艺术:深入了解 AVL 树的核心原理与实现
Lenyiin
C++ 修炼全景指南 技术指南 c++ 数据结构 stl
摘要本文深入探讨了AVL树(自平衡二叉搜索树)的概念、特点以及实现细节。我们首先介绍了AVL树的基本原理,并详细分析了其四种旋转操作,包括左旋、右旋、左右双旋和右左双旋,阐述了它们在保持树平衡中的重要作用。接着,本文从头到尾详细描述了AVL树的插入、删除和查找操作,配合完整的代码实现和详尽的注释,使读者能够全面理解这些操作的执行过程。此外,我们还提供了AVL树的遍历方法,包括中序、前序和后序遍历,
JAVA学习笔记之23种设计模式学习
victorfreedom
Java技术 设计模式 android java 常用设计模式
博主最近买了《设计模式》这本书来学习,无奈这本书是以C++语言为基础进行说明,整个学习流程下来效率不是很高,虽然有的设计模式通俗易懂,但感觉还是没有充分的掌握了所有的设计模式。于是博主百度了一番,发现有大神写过了这方面的问题,于是博主迅速拿来学习。一、设计模式的分类总体来说设计模式分为三大类:创建型模式,共五种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。结构型模式,共七种:适配器
c++ opencv4.3 sift匹配
图像处理大大大大大牛啊
图像处理 opencv实战代码讲解 opencv sift c++ opencv4 特征点
c++opencv4.3sift匹配main.cppintmain(){vectorkeypoints1,keypoints2;Matimg1,img2,descriptors1,descriptors2;intnumF
《 C++ 修炼全景指南:四 》揭秘 C++ List 容器背后的实现原理,带你构建自己的双向链表
Lenyiin
技术指南 C++ 修炼全景指南 c++ list 链表 stl
本篇博客,我们将详细讲解如何从头实现一个功能齐全且强大的C++List容器,并深入到各个细节。这篇博客将包括每一步的代码实现、解释以及扩展功能的探讨,目标是让初学者也能轻松理解。一、简介1.1、背景介绍在C++中,std::list是一个基于双向链表的容器,允许高效的插入和删除操作,适用于频繁插入和删除操作的场景。与动态数组不同,list允许常数时间内的插入和删除操作,支持双向遍历。这篇文章将详细
c++ 内存处理函数
heeheeai
c++ 开发语言
在C语言的头文件中,memcpy和memmove函数都用于复制内存块,但它们在处理内存重叠方面存在关键区别:内存重叠:memcpy函数不保证在源内存和目标内存区域重叠时能够正确复制数据。如果内存区域重叠,memcpy的行为是未定义的,可能会导致数据损坏或程序崩溃。memmove函数能够安全地处理源内存和目标内存区域重叠的情况。它会确保在复制过程中不会覆盖尚未复制的数据,从而保证数据的完整性。效率:
【c++基础概念深度理解——堆和栈的区别,并实现堆溢出和栈溢出】
XWWW668899
C++基本概念 c++ c语言 开发语言 青少年编程
文章目录概要技术名词解释栈溢出和堆溢出小结概要学习C++语言,避免不了要好好理解一下堆(Heap)和栈(Stack),有助于更好地管理内存,以及如何写出一段程序“成功实现”堆溢出和栈溢出。技术名词解释理解东西最快的方式是根据自己目前能理解的词语去关联新的概念,不断的纠正,向正确的深度理解靠近,当无限接近的时候也就理解了想要理解的概念。我们经常说堆栈,把这两个名词放到一起。其实,堆是堆,栈是栈,两种
C++常见知识掌握
nfgo
c++ 开发语言
1.Linux软件开发、调试与维护内核与系统结构Linux内核是操作系统的核心,负责管理硬件资源,提供系统服务,它是系统软件与硬件之间的桥梁。主要组成部分包括:进程管理:内核通过调度器分配CPU时间给各个进程,实现进程的创建、调度、终止等操作。使用进程描述符(task_struct)来存储进程信息,包括状态(就绪、运行、阻塞等)、优先级、内存映射等。内存管理:包括物理内存和虚拟内存管理。通过页表映
【Golang】实现 Excel 文件下载功能
RumIV
Golang golang excel 开发语言
在当今的网络应用开发中,提供数据导出功能是一项常见的需求。Excel作为一种广泛使用的电子表格格式,通常是数据导出的首选格式之一。在本教程中,我们将学习如何使用Go语言和GinWeb框架来创建一个Excel文件,并允许用户通过HTTP请求下载该文件。准备工作在开始之前,请确保您的开发环境中已经安装了Go语言和相关的开发工具。此外,您还需要安装GinWeb框架和excelize包,这两个包都将用于我
metaRTC5.0 API编程指南(一)
metaRTC
metaRTC c++ c语言 webrtc
概述metaRTC5.0版本API进行了重构,本篇文章将介绍webrtc传输调用流程和例子。metaRTC5.0版本提供了C++和纯C两种接口。纯C接口YangPeerConnection头文件:include/yangrtc/YangPeerConnection.htypedefstruct{void*conn;YangAVInfo*avinfo;YangStreamConfigstreamco
sublime个人设置
bawangtianzun
sublime text 编辑器
如何拥有jiangly蒋老师同款编译器(sublimec++配置竞赛向)_哔哩哔哩_bilibiliSublimeText4的安装教程(新手竞赛向)-知乎(zhihu.com)创建文件自动保存为c++打开SublimeText软件。转到"Tools"(工具)>"Developer"(开发者)>"NewPlugin"(新建插件)。在打开的新文件中,粘贴以下代码:importsublimeimport
【Golang】使用 Golang 语言和 excelize 库将数据写入Excel
不爱洗脚的小滕
golang excel 开发语言
文章目录前言一、Excelize简介二、代码实现1.获取依赖2.示例代码三、总结前言在数据处理和分析中,Excel作为一种常见的电子表格格式,被广泛应用于各种场景。然而,如何在Go语言中有效地处理Excel文件呢?在这篇博客中,我将介绍如何使用Go语言和excelize库将数据写入Excel文件。一、Excelize简介Excelize是一个用于读取和写入MicrosoftExcel™(XLSX)
面向对象面向过程
3213213333332132
java
面向对象:把要完成的一件事,通过对象间的协作实现。
面向过程:把要完成的一件事,通过循序依次调用各个模块实现。
我把大象装进冰箱这件事为例,用面向对象和面向过程实现,都是用java代码完成。
1、面向对象
package bigDemo.ObjectOriented;
/**
* 大象类
*
* @Description
* @author FuJian
Java Hotspot: Remove the Permanent Generation
bookjovi
HotSpot
openjdk上关于hotspot将移除永久带的描述非常详细,http://openjdk.java.net/jeps/122
JEP 122: Remove the Permanent Generation
Author Jon Masamitsu
Organization Oracle
Created 2010/8/15
Updated 2011/
正则表达式向前查找向后查找,环绕或零宽断言
dcj3sjt126com
正则表达式
向前查找和向后查找
1. 向前查找:根据要匹配的字符序列后面存在一个特定的字符序列(肯定式向前查找)或不存在一个特定的序列(否定式向前查找)来决定是否匹配。.NET将向前查找称之为零宽度向前查找断言。
对于向前查找,出现在指定项之后的字符序列不会被正则表达式引擎返回。
2. 向后查找:一个要匹配的字符序列前面有或者没有指定的
BaseDao
171815164
seda
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public Conn
Ant标签详解--Java命令
g21121
Java命令
这一篇主要介绍与java相关标签的使用 终于开始重头戏了,Java部分是我们关注的重点也是项目中用处最多的部分。
1
[简单]代码片段_电梯数字排列
53873039oycg
代码
今天看电梯数字排列是9 18 26这样呈倒N排列的,写了个类似的打印例子,如下:
import java.util.Arrays;
public class 电梯数字排列_S3_Test {
public static void main(S
Hessian原理
云端月影
hessian原理
Hessian 原理分析
一. 远程通讯协议的基本原理
网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络 IO 来实现,其中传输协议比较出名的有 http 、 tcp 、 udp 等等, http 、 tcp 、 udp 都是在基于 Socket 概念上为某类应用场景而扩展出的传输协
区分Activity的四种加载模式----以及Intent的setFlags
aijuans
android
在多Activity开发中,有可能是自己应用之间的Activity跳转,或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例,而不是产生大量重复的Activity。
这需要为Activity配置特定的加载模式,而不是使用默认的加载模式。 加载模式分类及在哪里配置
Activity有四种加载模式:
standard
singleTop
hibernate几个核心API及其查询分析
antonyup_2006
html .net Hibernate xml 配置管理
(一) org.hibernate.cfg.Configuration类
读取配置文件并创建唯一的SessionFactory对象.(一般,程序初始化hibernate时创建.)
Configuration co
PL/SQL的流程控制
百合不是茶
oracle PL/SQL编程 循环控制
PL/SQL也是一门高级语言,所以流程控制是必须要有的,oracle数据库的pl/sql比sqlserver数据库要难,很多pl/sql中有的sqlserver里面没有
流程控制;
分支语句 if 条件 then 结果 else 结果 end if ;
条件语句 case when 条件 then 结果;
循环语句 loop
强大的Mockito测试框架
bijian1013
mockito 单元测试
一.自动生成Mock类 在需要Mock的属性上标记@Mock注解,然后@RunWith中配置Mockito的TestRunner或者在setUp()方法中显示调用MockitoAnnotations.initMocks(this);生成Mock类即可。二.自动注入Mock类到被测试类 &nbs
精通Oracle10编程SQL(11)开发子程序
bijian1013
oracle 数据库 plsql
/*
*开发子程序
*/
--子程序目是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用程序中多次调用
--PL/SQL有两种类型的子程序:过程和函数
--开发过程
--建立过程:不带任何参数
CREATE OR REPLACE PROCEDURE out_time
IS
BEGIN
DBMS_OUTPUT.put_line(systimestamp);
E
【EhCache一】EhCache版Hello World
bit1129
Hello world
本篇是EhCache系列的第一篇,总体介绍使用EhCache缓存进行CRUD的API的基本使用,更细节的内容包括EhCache源代码和设计、实现原理在接下来的文章中进行介绍
环境准备
1.新建Maven项目
2.添加EhCache的Maven依赖
<dependency>
<groupId>ne
学习EJB3基础知识笔记
白糖_
bean Hibernate jboss webservice ejb
最近项目进入系统测试阶段,全赖袁大虾领导有力,保持一周零bug记录,这也让自己腾出不少时间补充知识。花了两天时间把“传智播客EJB3.0”看完了,EJB基本的知识也有些了解,在这记录下EJB的部分知识,以供自己以后复习使用。
EJB是sun的服务器端组件模型,最大的用处是部署分布式应用程序。EJB (Enterprise JavaBean)是J2EE的一部分,定义了一个用于开发基
angular.bootstrap
boyitech
AngularJS AngularJS API angular中文api
angular.bootstrap
描述:
手动初始化angular。
这个函数会自动检测创建的module有没有被加载多次,如果有则会在浏览器的控制台打出警告日志,并且不会再次加载。这样可以避免在程序运行过程中许多奇怪的问题发生。
使用方法: angular .
java-谷歌面试题-给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数
bylijinnan
java
public class SearchInShiftedArray {
/**
* 题目:给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数。
* 请在这个特殊数组中找出给定的整数。
* 解答:
* 其实就是“旋转数组”。旋转数组的最小元素见http://bylijinnan.iteye.com/bl
天使还是魔鬼?都是我们制造
ducklsl
生活 教育 情感
----------------------------剧透请原谅,有兴趣的朋友可以自己看看电影,互相讨论哦!!!
从厦门回来的动车上,无意中瞟到了书中推荐的几部关于儿童的电影。当然,这几部电影可能会另大家失望,并不是类似小鬼当家的电影,而是关于“坏小孩”的电影!
自己挑了两部先看了看,但是发现看完之后,心里久久不能平
[机器智能与生物]研究生物智能的问题
comsci
生物
我想,人的神经网络和苍蝇的神经网络,并没有本质的区别...就是大规模拓扑系统和中小规模拓扑分析的区别....
但是,如果去研究活体人类的神经网络和脑系统,可能会受到一些法律和道德方面的限制,而且研究结果也不一定可靠,那么希望从事生物神经网络研究的朋友,不如把
获取Android Device的信息
dai_lm
android
String phoneInfo = "PRODUCT: " + android.os.Build.PRODUCT;
phoneInfo += ", CPU_ABI: " + android.os.Build.CPU_ABI;
phoneInfo += ", TAGS: " + android.os.Build.TAGS;
ph
最佳字符串匹配算法(Damerau-Levenshtein距离算法)的Java实现
datamachine
java 算法 字符串匹配
原文:http://www.javacodegeeks.com/2013/11/java-implementation-of-optimal-string-alignment.html------------------------------------------------------------------------------------------------------------
小学5年级英语单词背诵第一课
dcj3sjt126com
english word
long 长的
show 给...看,出示
mouth 口,嘴
write 写
use 用,使用
take 拿,带来
hand 手
clever 聪明的
often 经常
wash 洗
slow 慢的
house 房子
water 水
clean 清洁的
supper 晚餐
out 在外
face 脸,
macvim的使用实战
dcj3sjt126com
mac vim
macvim用的是mac里面的vim, 只不过是一个GUI的APP, 相当于一个壳
1. 下载macvim
https://code.google.com/p/macvim/
2. 了解macvim
:h vim的使用帮助信息
:h macvim
java二分法查找
蕃薯耀
java二分法查找 二分法 java二分法
java二分法查找
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月23日 11:40:03 星期二
http:/
Spring Cache注解+Memcached
hanqunfeng
spring memcached
Spring3.1 Cache注解
依赖jar包:
<!-- simple-spring-memcached -->
<dependency>
<groupId>com.google.code.simple-spring-memcached</groupId>
<artifactId>simple-s
apache commons io包快速入门
jackyrong
apache commons
原文参考
http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html
Apache Commons IO 包绝对是好东西,地址在http://commons.apache.org/proper/commons-io/,下面用例子分别介绍:
1) 工具类
2
如何学习编程
lampcy
java 编程 C++ c
首先,我想说一下学习思想.学编程其实跟网络游戏有着类似的效果.开始的时候,你会对那些代码,函数等产生很大的兴趣,尤其是刚接触编程的人,刚学习第一种语言的人.可是,当你一步步深入的时候,你会发现你没有了以前那种斗志.就好象你在玩韩国泡菜网游似的,玩到一定程度,每天就是练级练级,完全是一个想冲到高级别的意志力在支持着你.而学编程就更难了,学了两个月后,总是觉得你好象全都学会了,却又什么都做不了,又没有
架构师之spring-----spring3.0新特性的bean加载控制@DependsOn和@Lazy
nannan408
Spring3
1.前言。
如题。
2.描述。
@DependsOn用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean。
@DependsOn({"steelAxe","abc"})
@Comp
Spring4+quartz2的配置和代码方式调度
Everyday都不同
代码 配置 spring4 quartz2.x 定时任务
前言:这些天简直被quartz虐哭。。因为quartz 2.x版本相比quartz1.x版本的API改动太多,所以,只好自己去查阅底层API……
quartz定时任务必须搞清楚几个概念:
JobDetail——处理类
Trigger——触发器,指定触发时间,必须要有JobDetail属性,即触发对象
Scheduler——调度器,组织处理类和触发器,配置方式一般只需指定触发
Hibernate入门
tntxia
Hibernate
前言
使用面向对象的语言和关系型的数据库,开发起来很繁琐,费时。由于现在流行的数据库都不面向对象。Hibernate 是一个Java的ORM(Object/Relational Mapping)解决方案。
Hibernte不仅关心把Java对象对应到数据库的表中,而且提供了请求和检索的方法。简化了手工进行JDBC操作的流程。
如
Math类
xiaoxing598
Math
一、Java中的数字(Math)类是final类,不可继承。
1、常数 PI:double圆周率 E:double自然对数
2、截取(注意方法的返回类型) double ceil(double d) 返回不小于d的最小整数 double floor(double d) 返回不大于d的整最大数 int round(float f) 返回四舍五入后的整数 long round