拼吾爱程序人生

首页 » .Net编程 » C# » 如何把图片插入Excel的一个单元格中
SystemPoster - 2007-8-9 9:09:00
前段时间做了个用于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);
//        v_BinaryWriter.Write(v_Bytes);
        for(int i=0;i<v_Bytes.Length;i++)
        {
            v_BinaryWriter.Write(v_Bytes);
        }
        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;
}

      打开一个Excel很简单

private bool WorkbookOpen(string p_strWorkBookName)
{
    //returns TRUE if the workbook is open
    if (appObject.Workbooks.get_Item(p_strWorkBookName) != null)
        return true;
    return false;
}

..
if(this.WorkbookOpen(workbookObject.Name))
{
    appObject.Visible = true;
}
..

 您可能对 [C#] 的这些文章也感兴趣:

c#中邮件收发处理(POP3,IMAP,SMTP)
C#的Hotkey简单封装
在C#中调用VC编写的dll库
C#操作RTF文档
C#和VB.NET版CLSA.NET 3.0电子图书面市
SmartSoft中用C#.Net实现AutoCAD块属性提取
C#编程中的 New 关键词的几种用法
winform绘图技术
C#实现Windows 服务的制作、安装和删除
C# 中的 @ 符号的使用及注意事项
C#生成bt种子
C#开源项目
1
查看完整版本: 如何把图片插入Excel的一个单元格中
Modify by pin5i DZNT_ExpandPackage 2.1.3295 2007-2009 pin5i.com
 Total Unique Visitors: