CPP QT实现excel的冻结窗格

在excel中录制宏可以获得以下vba代码:

    Range("C3").Select
    ActiveWindow.FreezePanes = True

然后根据以上代码去猜测cpp代码如何写,实际很难。但可以猜到关键函数SetFreezePanes。

网上有个C#的库NPOI,据说可以不安装office就可以操作excel,NPOI中有个函数CreateFreezePane实现了excel冻结窗格。
以后可以考虑下载C#的NPOI来参考着写CPP的office操作代码。

搜索:excel cpp SetFreezePanes(true) 可以找到以下网页:
https://blog.csdn.net/feng_a_feng/article/details/110084560
参考以后,封装函数如下:

bool FreezeSheet(Excel::Worksheet *sheet, const int iRowCount, const int iColCount)
{

	if (NULL == sheet)
	{
		return false;
	}
	if (iRowCount == 0 && iColCount == 0)
	{
		return false;
	}
	Excel::Range *range_used = sheet->UsedRange();
	if (range_used == NULL)
	{
		return false;
	}
	Excel::Range *range_rows = range_used->Rows();
	if (range_rows == NULL)
	{
		return false;
	}
	Excel::Range *range_cols = range_used->Columns();
	if (range_cols == NULL)
	{
		return false;
	}
	int excel_row_count = range_rows->Count();    //行数
	int excel_col_count = range_cols->Count();    //列数
	int iRowFreeze = iRowCount;
	int iColFreeze = iColCount;
	if (iRowCount > excel_row_count)
	{
		iRowFreeze = excel_row_count;
	}
	if (iColCount > excel_col_count)
	{
		iColFreeze = excel_col_count;
	}
	if (iRowFreeze == 0 && iColFreeze == 0)
	{
		return false;
	}
	//
	sheet->Activate();
	Excel::Window *pWindow = excel_->ActiveWindow();
	if (NULL == pWindow)
	{
		return false;
	}
	pWindow->SetFreezePanes(false); //首先先把冻结窗格去掉,防止Excel已经设置的冻结窗格导致后面设置的不成功。
	pWindow->SetSplitColumn(iColFreeze); //iColCount为0时,只冻结行
	pWindow->SetSplitRow(iRowFreeze); //iRowCount为0时,只冻结列
	pWindow->SetFreezePanes(true); //设置冻结窗格属性为true
	return true;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值