2.4.4 用NPOI操作EXCEL--画Grid

  在NPOI中,本身没有画Grid的方法。但我们知道Grid其实就是由横线和竖线构成的,所在我们可以通过画线的方式来模拟画Grid。

 

复制代码
HSSFSheet sheet1 = hssfworkbook.CreateSheet("Sheet1");

HSSFRow row 
= sheet1.CreateRow(2);
row.CreateCell(
1);
row.HeightInPoints 
= 240;
sheet1.SetColumnWidth(
29000);
int linesCount = 20;

HSSFPatriarch patriarch 
= sheet1.CreateDrawingPatriarch();
//因为HSSFClientAnchor中dx只能在0-1023之间,dy只能在0-255之间,所以这里采用比例的方式
double xRatio = 1023.0 / (linesCount*10);
double yRatio = 255.0 / (linesCount*10);

//画竖线
int x1 = 0;
int y1 = 0;
int x2 = 0;
int y2 = 200;
for (int i = 0; i < linesCount; i++)
{
    HSSFClientAnchor a2 
= new HSSFClientAnchor();
    a2.SetAnchor((
short)22, (int)(x1 * xRatio), (int)(y1 * yRatio),
            (
short)22, (int)(x2 * xRatio), (int)(y2 * yRatio));
    HSSFSimpleShape shape2 
= patriarch.CreateSimpleShape(a2);
    shape2.ShapeType 
= (HSSFSimpleShape.OBJECT_TYPE_LINE);

    x1 
+= 10;
    x2 
+= 10;
}

//画横线
x1 = 0;
y1 
= 0;
x2 
= 200;
y2 
= 0;
for (int i = 0; i < linesCount; i++)
{
    HSSFClientAnchor a2 
= new HSSFClientAnchor();
    a2.SetAnchor((
short)22, (int)(x1 * xRatio), (int)(y1 * yRatio),
            (
short)22, (int)(x2 * xRatio), (int)(y2 * yRatio));
    HSSFSimpleShape shape2 
= patriarch.CreateSimpleShape(a2);
    shape2.ShapeType 
= (HSSFSimpleShape.OBJECT_TYPE_LINE);

    y1 
+= 10;
    y2 
+= 10;
}
复制代码

请注意HSSFClientAnchor对象中的dx只能取0-1023之间的数,dy只能取0-255之间的数。我们可以理解为是将单元格的宽和高平分成了1023和255份,设置dx和dy时相当于按比例取对应的座标。最终生成的Excel如下:

 

返回目录

 

posted @   atao.xiang  阅读(7137)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?
< 2009年10月 >
27 28 29 30 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
1 2 3 4 5 6 7
点击右上角即可分享
微信分享提示