给原有的excel文件中插入图片

public static void main(String[] args) {

		FileOutputStream fileOut = null;

		BufferedImage bufferImg = null;

		try {

			// 先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray
			ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();

			bufferImg = ImageIO.read(new File("d:/test/aaa.jpg"));

			ImageIO.write(bufferImg, "jpg", byteArrayOut);

			// 创建一个工作薄
			HSSFWorkbook wb = new HSSFWorkbook(new FileInputStream("d:/jlzf_jlz.xls"));
			
			HSSFSheet sheet1 = wb.getSheetAt(0);

			HSSFPatriarch patriarch = sheet1.createDrawingPatriarch();
			//HSSFClientAnchor几个数字解释:3:是x轴的开始节点, 0: 是y轴的开始节点,1023:是x轴的结束节点,255:是y轴的结束节点,1:是从Excel的2列开始插入图片,10:是从excel的第11行开始插入图片, 11:图片占用11列的位置,25:图片结束在excel的26行
			HSSFClientAnchor anchor = new HSSFClientAnchor(3, 0, 1023, 255,(short) 1, 10,(short) 11, 25);
			
			anchor.setAnchorType(2);
			
			// 插入图片
			patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));

			fileOut = new FileOutputStream("d:/workbook.xls");
			
			// 写入excel文件
			wb.write(fileOut);
			
			fileOut.close();

		} catch (IOException io) {
			
			io.printStackTrace();

			System.out.println("io erorr :  " + io.getMessage());

		} finally {
			
			if (fileOut != null) {

				try {
					
					fileOut.close();
					
				} catch (IOException e) {
					
					e.printStackTrace();
					
				}
			}
		}
	}
所需jar包 点击下载
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值