MFC 制作表格 实现用户输入数据 ,存入数组并且写入txt文件中

本文介绍如何在MFC应用中使用列表控件(List Control)和编辑框(Edit Control)实现用户输入数据。通过双击列表控件进行内容编辑,利用Edit控件隐藏显示并修改列表数据。同时,当编辑框失去焦点时,将修改后的数据更新回列表。最后,通过OnBnClickedOk()函数将对话框中的数据保存到TXT文件中。
摘要由CSDN通过智能技术生成

未完待续
一、需要的控件:listControl 与edit Control
List Control获取指定行和列的编号,并获取指定行和列的内容及修改赋值。实现双击实现修改列表框内容
edit Control属性
位置任意,关联一个变量m_edit1,在OnInitDialog()函数中写入 m_edit.ShowWindow(SW_HIDE),作用为初始时讲编辑框隐藏
listControl 属性
view:report
关联一个变量如:m_list;然后响应该控件的NM_DBLCLK消息,也就是双击事件处理消息,代码如下:

NM_LISTVIEW* pNMListView=(NM_LISTVIEW*)pNMHDR;
	CRect rc;
	CString strTemp;
	m_Row = pNMListView->iItem;//获得选中的行
	m_Col = pNMListView->iSubItem;//获得选中列
	if(pNMListView->iItem == -1)//选择空白处添加一行,并且设置焦点为最后一行第二列
	{
		m_Row=m_diseaseList.GetItemCount();
		strTemp.Format(_T("%d"),m_Row+1);
		m_diseaseList.InsertItem(m_Row,strTemp);
		m_diseaseList.SetItemState(m_Row,LVIS_SELECTED|LVIS_FOCUSED,LVIS_SELECTED|LVIS_FOCUSED);
		m_diseaseList.EnsureVisible(m_Row,FALSE);

	}
	if   (pNMListView->iS
要使用MFC制作Excel表格,需要使用Microsoft Office的COM组件和MFC的COleVariant类。以下是一些基本步骤: 1. 添加Microsoft Excel的类型库 在Visual Studio,打开项目属性,选择“VC++目录”,在“包含目录”添加以下路径: C:\Program Files (x86)\Microsoft Office\root\VFS\ProgramFilesCommonX86\Microsoft Shared\OFFICE16 然后在“链接器”的“常规”添加以下路径: C:\Program Files (x86)\Microsoft Office\root\VFS\ProgramFilesCommonX86\Microsoft Shared\OFFICE16 最后在“链接器”的“输入添加以下库文件: Excel.lib, Ole32.lib 2. 创建COleVariant对象 使用COleVariant类可以将数据转换为Excel数据类型。例如,要将一个数字转换为Excel的数字类型,可以使用以下代码: COleVariant var(10.0); 3. 打开Excel应用程序 使用以下代码可以打开Excel应用程序: _Application app; if (!app.CreateDispatch(_T("Excel.Application"))) { AfxMessageBox(_T("Failed to create Excel application!")); return; } 4. 获取工作簿和工作表 要在Excel创建表格,首先需要获取一个工作簿和一个工作表。可以使用以下代码获取一个新的工作簿: _Workbook book; book.AttachDispatch(app.get_Workbooks()->Add()); // 新建工作簿 然后可以使用以下代码获取第一个工作表: _Worksheet sheet; sheet.AttachDispatch(book.get_Worksheets()->Item(COleVariant((short)1))); 5. 设置单元格的 使用以下代码可以设置单元格的: sheet.put_Range(_T("A1"), _T("Hello")); sheet.put_Range(_T("B1"), COleVariant(10.0)); 6. 保存并关闭Excel 最后,使用以下代码保存并关闭Excel应用程序: book.SaveAs(COleVariant(_T("D:\\test.xlsx")), COleVariant((short)51)); book.Close(COleVariant((short)0)); app.Quit(); 注意:使用COM组件需要注意内存泄漏的问题,在关闭Excel应用程序之前需要释放所有的COM对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值