好心人帮帮忙

yb210021 2009-08-11 02:55:38
以下是我从网上找到的一个关于报表的方法,但为什么我用EVC编译的时候,在板子上不显示报表呢!而只执行到Falied!,即只显示Failed!,后面的程序没有执行,原因可能是没有打开WORD!但请问各位要怎么改才能显示啊?
1、Ctrl + W Add Class From a type Library C:\Program Files\Microsoft Office\OFFICE11\MSWORD.OLB 添加_Application, _Document, _Font, _ParagraphFormat, Borders, Cell, Cells, Columns, Documents, Range, Row, Rows, Selection, Table, Tables

2、添加如下代码

BOOL C***App::InitInstance()
{
if (!AfxOleInit())
{
AfxMessageBox(IDP_OLE_INIT_FAILED);
return FALSE;
}

……
}

3、添加一按钮,生成报表代码如下:

void C***Dlg::OnButton1()
{
// TODO: Add your control notification handler code here
CString strField[8],strTop;
strField[0]="商品编号";
strField[1]="商品名称";
strField[2]="现有数量";
strField[3]="价 格";
strField[4]="采购数量";
strField[5]="采购价格";
strField[6]="供应商";
strField[7]="计划采购时间";

CString Title="计划采购信息";

CWaitCursor wait;
_Application wordApp;
_Document wordDoc;
Documents wordDocs;
if(!wordApp.CreateDispatch("word.Application"))
{
AfxMessageBox("Failed!");
return;
}
LPDISPATCH pDocs=wordApp.GetDocuments();
wordDocs.AttachDispatch(pDocs);
VARIANT varUnit;
VARIANT varOptional;
VariantInit(&varUnit);
varUnit.vt=VT_I4;
varUnit.lVal=5;
//
VariantInit(&varOptional);
varOptional.vt=VT_ERROR;
varOptional.scode=DISP_E_PARAMNOTFOUND;
//
LPDISPATCH pDoc=wordDocs.Add(&varOptional,&varOptional,&varOptional,&varOptional);
wordDoc.AttachDispatch(pDoc);

long nRows,nCols;
nRows=8;
nCols=8;
//
Range wordRange;
wordRange=wordDoc.Range(&varOptional,&varOptional);
//
Selection wordSelec=wordApp.GetSelection();
_Font oFont;
_ParagraphFormat wordFormat;

//标题
wordSelec.HomeKey(&varUnit,&varOptional);

oFont=wordSelec.GetFont();
oFont.SetSize(12);
oFont.SetName("宋体");
wordFormat=wordSelec.GetParagraphFormat();
wordFormat.SetAlignment(1);
wordSelec.InsertAfter(LPCSTR(Title));
wordSelec.InsertParagraphAfter();

oFont.SetSize(16);
oFont.SetName("黑体");
wordFormat=wordSelec.GetParagraphFormat();
wordFormat.SetAlignment(1);
wordSelec.InsertAfter(LPCSTR(strTop));
wordSelec.InsertParagraphAfter();

wordSelec.EndKey(&varUnit,&varOptional);

//设置表格
wordRange=wordSelec.GetRange();
oFont=wordSelec.GetFont();
oFont.SetSize(10);
oFont.SetName("宋体");
wordFormat=wordSelec.GetParagraphFormat();
wordFormat.SetAlignment(1);

VARIANT varTable;
VariantInit(&varTable);
varUnit.vt=VT_I4;
varUnit.lVal=0;
//
Tables wordTables=wordSelec.GetTables();
Table wordTable=wordTables.Add(wordRange,nRows,nCols,&varOptional,&varTable);
//
Borders tblBorders;
tblBorders=wordTable.GetBorders();
tblBorders.SetInsideLineStyle(1);
tblBorders.SetOutsideLineStyle(7);
//
Columns tblColumns;
tblColumns=wordTable.GetColumns();
tblColumns.GetPreferredWidthType();
//
int i,j,n;
char buf[50];
CString strValue;
Cell tblCell;

for(i=1;i<=nRows;i++)
{
for(j=1;j<=nCols;j++)
{
if(i==1)
{
tblCell=wordTable.Cell(i,j);
wordRange=tblCell.GetRange();
oFont=wordRange.GetFont();
oFont.SetName("黑体");
n=j-1;
strValue=strField[n];
wordRange.InsertAfter(strValue);
}
else
{
tblCell=wordTable.Cell(i,j);
wordRange=tblCell.GetRange();
n=j-1;
if(n==0 || n==1 || n==6)
{
strValue="016";
}
if(n==2 || n==3 || n==4 ||n==5)
{
strValue="2345";
}
if(n==7)
{
strValue="7";
}
//strValue.TrimRight();
wordRange.InsertAfter(strValue);
}
}

}
wordApp.SetVisible(true);
wordDoc.Activate();
}

...全文
113 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
yb210021 2009-08-11
  • 打赏
  • 举报
回复
什么意思啊,不太明白?
feilinhe 2009-08-11
  • 打赏
  • 举报
回复
Word.Application试试
快乐鹦鹉 2009-08-11
  • 打赏
  • 举报
回复
???
yb210021 2009-08-11
  • 打赏
  • 举报
回复
???

16,551

社区成员

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

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

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