📄 testview.cpp
字号:
// TestView.cpp : CTestView 类的实现
//
#include "stdafx.h"
#include "Test.h"
#include "TestDoc.h"
#include "TestView.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// CTestView
IMPLEMENT_DYNCREATE(CTestView, CView)
BEGIN_MESSAGE_MAP(CTestView, CView)
// 标准打印命令
ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
ON_WM_RBUTTONDOWN()
ON_WM_LBUTTONDOWN()
END_MESSAGE_MAP()
// CTestView 构造/销毁
CTestView::CTestView()
{
// TODO: 在此处添加构造代码
}
CTestView::~CTestView()
{
}
BOOL CTestView::PreCreateWindow(CREATESTRUCT& cs)
{
// TODO: 在此处通过修改 CREATESTRUCT cs 来修改窗口类或
// 样式
return CView::PreCreateWindow(cs);
}
// CTestView 绘制
void CTestView::OnDraw(CDC* /*pDC*/)
{
CTestDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
// TODO: 在此处为本机数据添加绘制代码
}
// CTestView 打印
BOOL CTestView::OnPreparePrinting(CPrintInfo* pInfo)
{
// 默认准备
return DoPreparePrinting(pInfo);
}
void CTestView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: 打印前添加额外的初始化
}
void CTestView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: 打印后添加清除过程
}
// CTestView 诊断
#ifdef _DEBUG
void CTestView::AssertValid() const
{
CView::AssertValid();
}
void CTestView::Dump(CDumpContext& dc) const
{
CView::Dump(dc);
}
CTestDoc* CTestView::GetDocument() const // 非调试版本是内联的
{
ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTestDoc)));
return (CTestDoc*)m_pDocument;
}
#endif //_DEBUG
// CTestView 消息处理程序
#include <afxdb.h>
void CTestView::OnRButtonDown(UINT nFlags, CPoint point)
{
CDatabase DB;
//Excel安装驱动
CString StrDriver = "MICROSOFT EXCEL DRIVER (*.XLS)";
//要建立的Excel文件
CString StrExcelFile = "C:\\MyExcel.xls";
CString StrSQL;
StrSQL.Format("DRIVER={%s};DSN='';FIRSTROWHASNameS=1;READONLY=FALSE;CREATE_DB=\"%s\";DBQ=%s",StrDriver,StrExcelFile,StrExcelFile);
TRY
{
// 创建Excel表格文件)
if(DB.OpenEx(StrSQL,CDatabase::noOdbcDialog) )
{
//创建表结构 字段名不能是Index
StrSQL = "CREATE TABLE MyExcel (股票代码 TEXT,股票名称 TEXT,收盘价 NUMBER)";
DB.ExecuteSQL(StrSQL);
//插入数值
StrSQL = "INSERT INTO MyExcel (股票代码,股票名称,收盘价) VALUES ('600006','东风汽车','12.90')";
DB.ExecuteSQL(StrSQL);
StrSQL = "INSERT INTO MyExcel (股票代码,股票名称,收盘价) VALUES ('600066','宇通客车','17.60')";
DB.ExecuteSQL(StrSQL);
StrSQL = "INSERT INTO MyExcel (股票代码,股票名称,收盘价) VALUES ('600736','苏州高新','7.58')";
DB.ExecuteSQL(StrSQL);
}
// 关闭数据库
DB.Close();
}
CATCH_ALL(e)
{
TRACE1("没有安装Excel驱动: %s",StrDriver);
}
END_CATCH_ALL;
MessageBox("C:\\MyExcel.xls文件创建成功!","信息提示",MB_OK);
CView::OnRButtonDown(nFlags, point);
}
#include <afxdb.h>
void CTestView::OnLButtonDown(UINT nFlags, CPoint point)
{
CDatabase DB;
CString StrSQL;
CString StrDsn;
//将被读取的Excel文件名
CString StrFile = "C:\\MyExcel.xls";
// 创建进行存取的字符串
StrDsn.Format("ODBC;DRIVER={MICROSOFT EXCEL DRIVER (*.XLS)};DSN='';DBQ=C:\\MyExcel.xls");
TRY
{
// 打开Excel文件)
DB.Open(NULL, false, false, StrDsn);
CRecordset DBSet(&DB);
// 设置读取的查询语句
StrSQL = "SELECT * FROM MyExcel";
//执行查询语句
DBSet.Open(CRecordset::forwardOnly, StrSQL, CRecordset::readOnly);
// 获取查询结果
CString StrInfo="股票代码 股票名称 收盘价 \n";
while (!DBSet.IsEOF())
{
//读取Excel内部数值
for(int i=0;i<DBSet.GetODBCFieldCount();i++)
{
CString Str;
DBSet.GetFieldValue(i, Str);
StrInfo+=Str+" ";
}
StrInfo+="\n";
DBSet.MoveNext();
}
MessageBox(StrInfo,"信息提示",MB_OK);
// 关闭数据库
DB.Close();
}
CATCH(CDBException, e)
{
// 数据库操作产生异常时...
AfxMessageBox("数据库错误: " + e->m_strError);
}
END_CATCH;
CView::OnLButtonDown(nFlags, point);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -