如何把图片插入Excel的一个单元格中

该博客为转载内容,转载自https://www.cnblogs.com/qingyang/archive/2005/08/30/226560.html ,涉及数据库相关知识。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前段时间做了个用于winform的Excel的插件程序,将从数据库中的image字段读出来后显示在excel中,在csdn上见过好几个提出这方面的问题,现将我的部分代码贴出来,分享给有需要的朋友。
我的这个是excel的插件程序,建的是vs.net 2003中的Addin工程,同时适用 vsto程序。
需要添加COM组件--Microsoft Excel 11.0 Object Library 的引用。
代码的核心在图片的转换和设置excel显示图片的单元格

这个方法转换图片,传入一个excel的workbook对象和转换成字符型的image字段。
private   void  ExtractPicture(Excel.Workbook p_Workbook,   string   p_imageStr)
{
    
byte [] v_Bytes  =  Convert.FromBase64String(p_imageStr);
    
if  (v_Bytes.Length  >   0 )
    {
        FileStream v_FileStream 
=   new  FileStream(p_Workbook.FullName  +   " .jpeg " , FileMode.CreateNew);
        BinaryWriter v_BinaryWriter 
=   new  BinaryWriter(v_FileStream);
        
for ( int  i = 0 ;i < v_Bytes.Length;i ++ )
        {
            v_BinaryWriter.Write(v_Bytes[i]);
        }
        v_BinaryWriter.Close();
        v_FileStream.Close();
    }
}

下面这个方法在Excel中设置图片位置。
private   void  SetPictureToRange(Excel.Workbook p_Workbook, Excel.Worksheet p_Worksheet,  string  p_strRangeName)
{
    Excel.Pictures v_Pictures 
=  (Excel.Pictures)p_Worksheet.Pictures(Type.Missing);
    Excel.Picture v_Picture 
=  v_Pictures.Insert(p_Workbook.FullName  +   " .jpeg " , Type.Missing);
    
//  Excel的get_Range方法可以得到Excel的单元格,可以用来设置图片显示的位置
    Excel.Range v_Range  =  p_Worksheet.get_Range(p_strRangeName, Type.Missing);
    
double  v_fFactor  =   1 ;
    
// 设置图片大小
     if  (v_Picture.Width  *  ( double )v_Range.Height  >  v_Picture.Height  *  ( double )v_Range.Width)
        v_fFactor 
=  ( double )v_Range.Width  /  ( double )v_Picture.Width;
    
else
        v_fFactor 
=  ( double )v_Range.Height  /  ( double )v_Picture.Height;
    v_Picture.Left 
=  ( double )v_Range.Left  +  (( double )v_Range.Width  -  (v_Picture.Width  *  v_fFactor))  /   2   +   1 ;
    v_Picture.Top 
=  ( double )v_Range.Top  +  (( double )v_Range.Height  -  (v_Picture.Height  *  v_fFactor))  /   2   +   1 ;
    v_Picture.Width 
=  v_Picture.Width  *  v_fFactor  -   0.5d ;
    v_Picture.Height 
=  v_Picture.Height  *  v_fFactor  -   0.5d ;
}

转载于:https://www.cnblogs.com/qingyang/archive/2005/08/30/226560.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值