--------------------- 本文来自 天水宇 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/xxs77ch/article/details/50553857?utm_source=copy

  • using System;
  • using System.Collections.Generic;
  • using System.Linq;
  • using System.Text;
  • using System.Threading.Tasks;
  • using NPOI.HSSF.UserModel;
  • using NPOI.SS.Formula.Eval;
  • using NPOI.SS.Formula.Functions;
  • using NPOI.SS.UserModel;
  • using NPOI.XSSF.UserModel;
  • using NPOI.POIFS.FileSystem;
  • using NPOI.HPSF;
  • using System.IO;
  • using NPOI.SS.Util;
  • using System.Drawing;
  • using NPOI.HSSF.Util;
  • using System.Web;
  • using System.Net;
  • using System.Net.Mail;
  • namespace NPOI
  • {
  • class Program10
  • {
  • static void Main(string[] args)
  • {
  •  
  • //说明:插入图片
  •  
  • //1.创建EXCEL中的Workbook
  • IWorkbook myworkbook = new HSSFWorkbook();
  •  
  • //2.创建Workbook中的Sheet
  • ISheet mysheet = myworkbook.CreateSheet("sheet1");
  •  
  • //第一步:读取图片到byte数组
  • HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://img1.soufunimg.com/message/images/card/tuanproj/201511/2015112703584458_s.jpg");
  •  
  • byte[] bytes;
  • using (Stream stream = request.GetResponse().GetResponseStream())
  • {
  • using (MemoryStream mstream = new MemoryStream())
  • {
  • int count = 0;
  • byte[] buffer = new byte[1024];
  • int readNum = 0;
  • while ((readNum = stream.Read(buffer, 0, 1024)) > 0)
  • {
  • count = count + readNum;
  • mstream.Write(buffer, 0, 1024);
  • }
  • mstream.Position = 0;
  • using (BinaryReader br = new BinaryReader(mstream))
  • {
  •  
  • bytes = br.ReadBytes(count);
  • }
  • }
  • }
  •  
  • //第二步:将图片添加到workbook中 指定图片格式 返回图片所在workbook->Picture数组中的索引地址(从1开始)
  • int pictureIdx = myworkbook.AddPicture(bytes, PictureType.JPEG);
  •  
  • //第三步:在sheet中创建画部
  • IDrawing patriarch = mysheet.CreateDrawingPatriarch();
  •  
  • //第四步:设置锚点 (在起始单元格的X坐标0-1023,Y的坐标0-255,在终止单元格的X坐标0-1023,Y的坐标0-255,起始单元格行数,列数,终止单元格行数,列数)
  • IClientAnchor anchor =patriarch.CreateAnchor(0,0,0,0,0,0,2,2);
  •  
  •  
  • //第五步:创建图片
  • IPicture pict = patriarch.CreatePicture(anchor, pictureIdx);
  •  
  • //6.保存
  • FileStream file = new FileStream(@"E:\myworkbook11.xls", FileMode.Create);
  • myworkbook.Write(file);
  • file.Close();
  • }
  • }
  • }
     
     
     
     
     
     1 // 插入 PNG 图片至 Excel
    2 String fileName = strAppRootPath + "images/" + "bxlogo.png";
    3
    4 InputStream is = new FileInputStream(fileName);
    5 byte[] bytes = IOUtils.toByteArray(is);
    6
    7 int pictureIdx = workbook.addPicture(bytes, Workbook.PICTURE_TYPE_PNG);
    8
    9 CreationHelper helper = workbook.getCreationHelper();
    10 Drawing drawing = sheet.createDrawingPatriarch();
    11 ClientAnchor anchor = helper.createClientAnchor();
    12
    13 // 图片插入坐标
    14 anchor.setCol1(0);
    15 anchor.setRow1(1);
    16 // 插入图片
    17 Picture pict = drawing.createPicture(anchor, pictureIdx);
    18 pict.resize();

NPOI2.2.0.0实例详解(十一)—向EXCEL插入图片的更多相关文章

  1. NPOI2.2.0.0实例详解(十)—设置EXCEL单元格【文本格式】 NPOI 单元格 格式设为文本 HSSFDataFormat

    NPOI2.2.0.0实例详解(十)—设置EXCEL单元格[文本格式] 2015年12月10日 09:55:17 阅读数:3150 using System; using System.Collect ...

  2. NPOI2.2.0.0实例详解(八)—设置EXCEL单元格【数字格式】

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  3. NPOI2.2.0.0实例详解(九)—设置EXCEL单元格【时间格式】

    原文:http://blog.csdn.net/xxs77ch/article/details/50245391 using System; using System.Collections.Gene ...

  4. RxJava2.0的使用详解

    RxJava2.0的使用详解 1,初识RxJava RxJava就是一种用Java语言实现的响应式编程,来创建基于事件的异步程序 RxJava是一个基于事件订阅的异步执行的一个类库,目前比较火的一些技 ...

  5. redis5.0.3配置文件详解

    Redis最新版本5.0.3配置文件详解 单位 #当你需要为某个配置项指定内存大小的时候,必须要带上单位, #通常的格式就是 1k 5gb 4m 等: #1k => 1000 bytes #1k ...

  6. IIS7.0 Appcmd 命令详解和定时重启应用池及站点的设置

    IIS7.0 Appcmd 命令详解 废话不说!虽然有配置界面管理器!但是做安装包的时候命令创建是必不可少的!最近使用NSIS制作安装包仔细研究了一下Appcmd的命令,可谓是功能齐全. 上网查了些资 ...

  7. loadrunner11.0 安装破解详解使用教程

    loadrunner11.0 安装破解详解使用教程 来源:互联网 作者:佚名 时间:01-21 10:25:34 [大 中 小] 很多朋友下载了loadrunner11但不是很会使用,这里简单介绍下安 ...

  8. Apache2.2+Tomcat7.0整合配置详解

    一.简单介绍 Apache.Tomcat Apache HTTP Server(简称 Apache),是 Apache 软件基金协会的一个开放源码的网页服务器,可以在 Windows.Unix.Lin ...

  9. IIS7.0 Appcmd 命令详解

    原文 IIS7.0 Appcmd 命令详解 一:准备工作 APPcmd.exe 位于 C:\Windows\System32\inetsrv 目录 使用 Cd c:\Windows\System32\ ...

随机推荐

  1. makefile,让编译更简单

    陈皓 (CSDN) 概述—— 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的 ...

  2. test20180919 递归问题

    题意 定义 \[ f(n)=\left\{ \begin{array}{} 1 & n=1\\ f(n-f(f(n-1)))+1 & n>1 \end{array} \right ...

  3. 自动AC机

    可以在lemon和cena环境下使用. #include<iostream> #include<cstdio> #include<cstring> #include ...

  4. 如何快速配好java环境变量和查看电脑上安装JDK的版本位数

    今天一个新手在群里问自己的Eclipse打不开,然后我是属于那种热心肠的人,一般自己知道的就会告诉他们,看了下,是环境变量没有配好,反正我觉得配环境比较简单,现在就教大家简单的环境变量配法 path ...

  5. 实习第二天-java参数传递-精华在文章最后2句话

    对于基本类型的传递,我们很容易理解,而对于对象,总让人感觉是按引用传递,看下面的程序: public class ObjectRef { //基本类型的参数传递 public static void ...

  6. flynn 开源paas 平台安装试用

    flynn 是一个不错的开源paas 平台,基于git 以及容器技术,开发模型与 heroku 基本一样,同时构建方式就是基于heroku 的buildpacks 安装 官方文档提示说明是ubuntu ...

  7. JMeter分布式部署的大致步骤以及误区解释

    master和slave机要在同一网段内,才能做分布式(Jmeter要配环境变量,这样不用手动起server) 分布式不成功,解决方案: 1.master端和slave端要ping通 2.ping通后 ...

  8. Python函数 dict()

    dict() 作用:dict() 函数用于创建一个字典.返回一个字典. 语法: class dict(**kwarg) class dict(mapping, **kwarg) class dict( ...

  9. Spring本质-AOP

    一.我们在做系统设计的时候,一个非常重要的工作就是把一个大系统做分解, 按业务功能分解成一个个低耦合.高内聚的模块,就像这样: 但是分解以后就会发现有些很有趣的东西, 这些东西是通用的,或者是跨越多个 ...

  10. POJ2955Brackets——dp

    题目:http://poj.org/problem?id=2955 1.考虑区间. 2.当前区间可为自己子区间的和(题意果然是和而非最大值). 3.考虑当前区间的边界. #include<ios ...