求助帖,急!VC中把DataGrid中的数据导出到EXCLE中是出错

阿勒。 2015-12-07 01:29:55
错误如下 求高人指教!
error C2678: binary '==' : no operator defined which takes a left-hand operand of type 'class CDataGrid' (or there is no acceptable conversion)

下面是代码 红色部分是出错的地方 if(m_datagrid=="个人信息表") 这里的m_datagrid(这是个DataGrid定义的变量)对吗,
还是得换成是给ADO DATA定义的变量m_adodc,==后面的应该是写我需要连接的SQL数据库中的表?
_Application app; //程序对象
Workbooks books; //工作簿集合
_Workbook book; //工作簿
Worksheets sheets; //工作表集合
_Worksheet sheet; //工作表
Range range; //单元格范围
//Font font; //字体
Range cols;
COleVariant covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);

if( !app.CreateDispatch("Excel.Application") )
{
this->MessageBox("无法创建Excel应用!");
return;}
books=app.GetWorkbooks();
book=books.Add(covOptional); //新建工作簿
sheets=book.GetSheets();
sheet=sheets.GetItem(COleVariant((short)1)); //以下是我的具体表

if(m_datagrid=="个人信息表")
{
range=sheet.GetRange(COleVariant("A1"),COleVariant("a1")); //字段名设置
range.SetValue2(COleVariant("Tid"));cols=range.GetEntireColumn();cols.SetColumnWidth(_variant_t((long)8)); //设置Excel列宽
range=sheet.GetRange(COleVariant("b1"),COleVariant("b1"));
range.SetValue2(COleVariant("Tname"));cols=range.GetEntireColumn();cols.AutoFit();
range=sheet.GetRange(COleVariant("c1"),COleVariant("c1"));
range.SetValue2(COleVariant("Sex"));cols=range.GetEntireColumn();cols.SetColumnWidth(_variant_t((long)12));
range=sheet.GetRange(COleVariant("d1"),COleVariant("d1"));
range.SetValue2(COleVariant("DOB"));cols=range.GetEntireColumn();cols.SetColumnWidth(_variant_t((long)12));
range=sheet.GetRange(COleVariant("e1"),COleVariant("e1"));
range.SetValue2(COleVariant("Xueli"));cols=range.GetEntireColumn();cols.AutoFit();
range=sheet.GetRange(COleVariant("f1"),COleVariant("f1"));
range.SetValue2(COleVariant("Lianxi"));cols=range.GetEntireColumn();cols.AutoFit();
range=sheet.GetRange(COleVariant("g1"),COleVariant("g1"));
range.SetValue2(COleVariant("Zhiwuleibieid"));cols=range.GetEntireColumn();cols.AutoFit();
range=sheet.GetRange(COleVariant("h1"),COleVariant("h1"));
range.SetValue2(COleVariant("Zhichengid"));cols=range.GetEntireColumn();cols.AutoFit();
range=sheet.GetRange(COleVariant("i1"),COleVariant("i1"));
range.SetValue2(COleVariant("Bumenid"));cols=range.GetEntireColumn();cols.AutoFit();//Range复位
}
int ss,nn; //双循环将m_datagrid中的数据全部导出到Excel
double dtotal;
dtotal=0;
CString cc;
nn=m_adodc.GetRecordset().GetRecordCount();
CColumns cls;
cls=m_datagrid.GetColumns();
ss=cls.GetCount();
for(int i=0;i<nn;i++)
{
m_datagrid.SetRow(i);
for(int j=0;j<ss;j++)
{
m_datagrid.SetCol(j);
cc=m_datagrid.GetText();
range.SetItem(_variant_t((long)(i+2)),_variant_t((long)(j+1)),_variant_t(cc));
}
}


app.SetVisible(TRUE); //设置Excel表可见
app.SetUserControl(TRUE); //设置Excel表可被操作
...全文
97 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
阿勒。 2015-12-07
  • 打赏
  • 举报
回复
引用 1 楼 lsq19871207 的回复:
m_datagrid是CDataGrid类型的变量,又不是字符串,当然不能和字符串比较了 你的意思是当m_datagrid显示的数据是个人信息表中的数据是导出,显示其他表数据不导出吗?我不知道CDataGrid类中有没有绑定相关的表名信息,但是你完全可以自己去控制和判断嘛,毕竟查表的时候你是知道查的是哪个表的,当查的表是个人信息表时,你设置一个标志位来供后续判断不就可以了吗?
这个是别人的程序,我又自己改的 if(m_table=="Ylypro") //原料油性质导出 (这里的m_table是什么啊 Ylypro是表名吗?我还以为他给DATAGRID设置的变量是m_table,太难的东西我也不会,我只是在ADO DATA的记录源里面写SQL语句来控制Datagrid里面显示什么,现在搞不懂这个m_table和Ylypro是什么,望指教,非常感谢) { range=sheet.GetRange(COleVariant("A1"),COleVariant("a1")); //字段名设置 range.SetValue2(COleVariant("厂名"));cols=range.GetEntireColumn();cols.SetColumnWidth(_variant_t((long)8)); //设置Excel列宽
信阳毛尖 2015-12-07
  • 打赏
  • 举报
回复
m_datagrid是CDataGrid类型的变量,又不是字符串,当然不能和字符串比较了 你的意思是当m_datagrid显示的数据是个人信息表中的数据是导出,显示其他表数据不导出吗?我不知道CDataGrid类中有没有绑定相关的表名信息,但是你完全可以自己去控制和判断嘛,毕竟查表的时候你是知道查的是哪个表的,当查的表是个人信息表时,你设置一个标志位来供后续判断不就可以了吗?

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧