C++中MFC编程,请问怎样在按按钮之后从.csv或者excel中读取数据到结构体?
就如同做一个通讯录程序,从.csv导入数据,编辑之后还可以导出数据。麻烦写上关键点,谢谢了,好的话有加分哦!txt也凑合,不要说“去查什么什么”,那样我就不用提问了不是吗...
就如同做一个通讯录程序,从.csv导入数据,编辑之后还可以导出数据。麻烦写上关键点,谢谢了,好的话有加分哦!txt也凑合,不要说“去查什么什么”,那样我就不用提问了不是吗?拜托了!
展开
若以下回答无法解决问题,邀请你更新回答
1个回答
展开全部
//////////////////////////////////////////////////////////////////////////////
//名称:OnOK
//功能:读取指定Excel文件内容
//作者:徐景周(jingzhou_xu@163.net)
//组织:未来工作室(Future Studio)
//日期:2003.5.1
///////////////////////////////////////////////////////////////////////
void CExcelAccessDlg::OnOK()
{
CSpreadSheet SS("c:\\Test.xls", "TestSheet");
CStringArray Rows, Column;
//清空列表框
m_AccessList.ResetContent();
for (int i = 1; i <= SS.GetTotalRows(); i++)
{
// 读取一行
SS.ReadRow(Rows, i);
CString strContents = "";
for (int j = 1; j <= Rows.GetSize(); j++)
{
if(j == 1)
strContents = Rows.GetAt(j-1);
else
strContents = strContents + " --> " + Rows.GetAt(j-1);
}
m_AccessList.AddString(strContents);
}
}
//////////////////////////////////////////////////////////////////////////////
//名称:OnWriteexcel
//功能:新建并写入Excel文件内容
//作者:徐景周(jingzhou_xu@163.net)
//组织:未来工作室(Future Studio)
//日期:2003.5.1
///////////////////////////////////////////////////////////////////////
void CExcelAccessDlg::OnWriteexcel()
{
// 新建Excel文件名及路径,TestSheet为内部表名
CSpreadSheet SS("c:\\Test.xls", "TestSheet");
CStringArray sampleArray, testRow;
SS.BeginTransaction();
// 加入标题
sampleArray.RemoveAll();
sampleArray.Add("姓名");
sampleArray.Add("年龄");
SS.AddHeaders(sampleArray);
// 加入数据
CString strName[] = {"徐景周","徐志慧","郭徽","牛英俊","朱小鹏"};
CString strAge[] = {"27","23","28","27","26"};
for(int i = 0; i < sizeof(strName)/sizeof(CString); i++)
{
sampleArray.RemoveAll();
sampleArray.Add(strName[i]);
sampleArray.Add(strAge[i]);
SS.AddRow(sampleArray);
}
// 初始化测试行数据,进行添加、插入及替换数据操作演示
for (int k = 1; k <= 2; k++)
{
testRow.Add("Test");
}
SS.AddRow(testRow); // 添加到尾部
SS.AddRow(testRow, 2); // 插入新行到第二行
SS.AddRow(testRow, 6, true); // 替换原第四行来新的内容
SS.Commit();
if(m_Check.GetCheck())
SS.Convert(";"); // 将原Excel文件转换为用分号分隔的文本,并另存为同名文本文件
AfxMessageBox("文件写入成功!");
}
//名称:OnOK
//功能:读取指定Excel文件内容
//作者:徐景周(jingzhou_xu@163.net)
//组织:未来工作室(Future Studio)
//日期:2003.5.1
///////////////////////////////////////////////////////////////////////
void CExcelAccessDlg::OnOK()
{
CSpreadSheet SS("c:\\Test.xls", "TestSheet");
CStringArray Rows, Column;
//清空列表框
m_AccessList.ResetContent();
for (int i = 1; i <= SS.GetTotalRows(); i++)
{
// 读取一行
SS.ReadRow(Rows, i);
CString strContents = "";
for (int j = 1; j <= Rows.GetSize(); j++)
{
if(j == 1)
strContents = Rows.GetAt(j-1);
else
strContents = strContents + " --> " + Rows.GetAt(j-1);
}
m_AccessList.AddString(strContents);
}
}
//////////////////////////////////////////////////////////////////////////////
//名称:OnWriteexcel
//功能:新建并写入Excel文件内容
//作者:徐景周(jingzhou_xu@163.net)
//组织:未来工作室(Future Studio)
//日期:2003.5.1
///////////////////////////////////////////////////////////////////////
void CExcelAccessDlg::OnWriteexcel()
{
// 新建Excel文件名及路径,TestSheet为内部表名
CSpreadSheet SS("c:\\Test.xls", "TestSheet");
CStringArray sampleArray, testRow;
SS.BeginTransaction();
// 加入标题
sampleArray.RemoveAll();
sampleArray.Add("姓名");
sampleArray.Add("年龄");
SS.AddHeaders(sampleArray);
// 加入数据
CString strName[] = {"徐景周","徐志慧","郭徽","牛英俊","朱小鹏"};
CString strAge[] = {"27","23","28","27","26"};
for(int i = 0; i < sizeof(strName)/sizeof(CString); i++)
{
sampleArray.RemoveAll();
sampleArray.Add(strName[i]);
sampleArray.Add(strAge[i]);
SS.AddRow(sampleArray);
}
// 初始化测试行数据,进行添加、插入及替换数据操作演示
for (int k = 1; k <= 2; k++)
{
testRow.Add("Test");
}
SS.AddRow(testRow); // 添加到尾部
SS.AddRow(testRow, 2); // 插入新行到第二行
SS.AddRow(testRow, 6, true); // 替换原第四行来新的内容
SS.Commit();
if(m_Check.GetCheck())
SS.Convert(";"); // 将原Excel文件转换为用分号分隔的文本,并另存为同名文本文件
AfxMessageBox("文件写入成功!");
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询