从 Excel 到 vb.net Picturebox 的图像

Posted

技术标签:

【中文标题】从 Excel 到 vb.net Picturebox 的图像【英文标题】:Image from Excel to vb.net Picturebox 【发布时间】:2016-05-18 14:37:18 【问题描述】:

我发现了很多关于 vb.net excel 的问题,但没有一个关于从 excel cell(row,column) 获取图片到图片框中的问题。我的应用程序是一个从 excel 文件中获取文本字符串的模板。效果很好,但现在我也在尝试传输图片。我试过picSpindle.Image = shXL.Cells(19, 2).Value,但什么也没做。不过不会出错!

复制和粘贴是否有效?

代码:

Imports System
Imports System.IO
Imports System.Text
Imports Excel = Microsoft.Office.Interop.Excel
Public Class Form1
    Dim appXL As Excel.Application
    Dim wbXl As Excel.Workbook
    Dim shXL As Excel.Worksheet
    Dim raXL As Excel.Range
    Dim PartID As String
    Dim RefCard As String

    Private Sub Form1_Activated(sender As System.Object, e As System.EventArgs) Handles MyBase.Activated
        'Dispaly Brembo Logo
        picLogo.SizeMode = PictureBoxSizeMode.StretchImage


    End Sub

    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        'Read File Source with part number ******************Example From TXT
        PartID = ("19.N111.10")

        ' Start Excel and get Application object.
        appXL = CreateObject("Excel.Application")
        appXL.Visible = False

        'Open Reference Card*************************************************************************************

        wbXl = appXL.Workbooks.Open("C:\Users\aholiday\Desktop\Visual Studios Projects\Reference Card App\" & PartID & ".xlsx")
        shXL = wbXl.Worksheets("Sheet1")

        ' Copys Reference Card Text from Cells To App labels
        lblCODE.Text = shXL.Cells(3, 9).Value
        Debug.Print(lblCODE.Text)
        lblREV.Text = shXL.Cells(3, 13).Value
        lblDate.Text = shXL.Cells(5, 9).Value
        lblCustomer.Text = shXL.Cells(8, 2).Value
        lblPart.Text = shXL.Cells(11, 2).Value
        lblSpindleType.Text = shXL.Cells(15, 2).Value
        lblPaintType.Text = shXL.Cells(7, 6).Value
        lblDunnageType.Text = shXL.Cells(8, 8).Value
        lblPartsLayer.Text = shXL.Cells(11, 11).Value
        lblLayers.Text = shXL.Cells(15, 11).Value
        lblTotalParts.Text = shXL.Cells(20, 11).Value
        lblPackagingInstructs.Text = shXL.Cells(20, 11).Value
     'Works up to here!

        ' Copys Reference Card Pictures from Cells To App Pictureboxs
        picSpindle.Image = shXL.Cells(19, 2).Value
        picRotorTop.Image = shXL.Cells(10, 6).Value
        picRotorBottom.Image = shXL.Cells(19, 6).Value
        picDunnageFinal.Image = shXL.Cells(10, 8).Value
        picDunnageLayer.Image = shXL.Cells(19, 8).Value


        ' Close objects
        raXL = Nothing
        shXL = Nothing
        wbXl = Nothing
        appXL.Quit()
        appXL = Nothing
    End Sub

End Class

【问题讨论】:

【参考方案1】:
shXL.Cells(19, 2).Value

等等都不起作用,因为图片没有存储在cells 中,而是在它们之上 这意味着values 这些cells 将是nothing

试试这些链接

1

2

3

【讨论】:

我决定将图片与带有文本字符串的 excel 文件一起放在一个文件夹中。我认为您可以按单元格复制图片,因为如果您在 excel 中记录宏并进行单元格复制和粘贴,它就可以工作。感谢您的信息。【参考方案2】:

图像不在单元格内。但是左上角的坐标指向一个单元格,使用上面的代码,您可以创建自己的搜索图像的函数。

你可以这样做:

    shXL = wbXl.Worksheets("Sheet1")

    ' # Loop for all Shapes 
    ' But I don't know what other controls over 
    '    the images are considered "shapes",
    '    Perhaps the best way is to verify that 
    '    in the "clipboard" there is truly a picture
    For i = 0 To shXL.Shapes.Count - 1

        'THIS IS THE MAIN POINT

        ' # get the pictures and copy to clipboard
        'shXL.Shapes.Item(i).Copy()

        ' # paste the picture in the pictureBox from clipboard
        'PictureBox1.Image = Clipboard.GetImage

        'AND OTHER PROPERTIS

        MsgBox(shXL.Shapes.Item(i).Name) ' the name in excel
        MsgBox(shXL.Shapes.Item(i).AlternativeText) 'the name of the file
        MsgBox(shXL.Shapes.Item(i).TopLeftCell.Column) 'the column position (of the top left corner)
        MsgBox(shXL.Shapes.Item(i).TopLeftCell.Row) 'the row position (of the top left corner)
        MsgBox(shXL.Shapes.Item(i).Width) 'the with in px
        MsgBox(shXL.Shapes.Item(i).Height) 'the height in px
        MsgBox(shXL.Shapes.Item(i).Top) 'the top in px
        MsgBox(shXL.Shapes.Item(i).Left) 'the left in px
    Next

【讨论】:

以上是关于从 Excel 到 vb.net Picturebox 的图像的主要内容,如果未能解决你的问题,请参考以下文章

VB.net中如何嵌套EXCEL?

从 Excel 导入数据 - VB.NET

将特定数据从excel导入到datagrid vb.net

从Excel到Access再到VB.NET学习过程小结

使用 VB.NET 表单从 SQL Server 到 Excel 的日期数据检索

Excel 到 SQL 表与 VB.net