Visual Basic - Excel单元格的边框属性

时间:2013-06-14 10:47:30

标签: visual-studio excel vba border

我是Visual Basic中的新手,我想建立一个在Excel文件上执行某些操作的简单应用程序。

我想编辑单元格的单元格边框属性,我需要编辑一些指定单元格的单独边框的重量和颜色(例如,只有底部边框或顶部边框)。

如果网上有一些有趣的资源: http://www.functionx.com/vbaexcel/cells/Lesson4.htm Border around each cell in a range http://social.msdn.microsoft.com/Forums/en-US/csharpgeneral/thread/93bb7ff7-0aed-4ce1-adca-aabde5fc3c2c

无论如何我不可能按照建议的例子。 这是我的代码的摘录:

Public Class mytest
Dim oExcel As Object 'Oggetto per la gestione del file Excel
Dim oBook As Object 'Oggetto per la gestione del file Excel
Dim page As Integer = 1 'Indice per la gestione dei fogli Excel
....

Private Sub Button1_Click(sender As System.Object, e As System.EventArgs) Handles Button1.Click
    'Creazione nuovo workbook in Excel
    oExcel = CreateObject("Excel.Application")
    oBook = oExcel.Workbooks.Add

    'Add data to cells of the first worksheet in the new workbook

    'Apertura file in lettura
    Using MyReader As New Microsoft.VisualBasic.FileIO.TextFieldParser("input.csv")
        MyReader.TextFieldType = FileIO.FieldType.Delimited
        'Imposto il carattere di separazione tra i campi
        MyReader.SetDelimiters(";")

        'Creo stringa lettura righe
        Dim currentRow As String()

        'Leggo 1 volta per saltare
        currentRow = MyReader.ReadFields()

        'Fino alla fine del file 
        While Not MyReader.EndOfData
            'Mostra riga nella label
            lblShowElab.Text = page
            Try
                'Formatto i fogli
                oBook.Worksheets(page).Range("A1:B1").Merge()
                oBook.Worksheets(page).Range("A2:B2").Merge()
    ...

                oBook.Worksheets(page).Range("B2").Borders(xlEdgeRight).LineStyle = xlContinuous
                oBook.Worksheets(page).Range("B2").Borders(xlEdgeRight).Weight = xlThin

                'Leggo riga per riga
                currentRow = MyReader.ReadFields()
                'Inserisco i campi di ogni riga nella cella voluta
                oBook.Worksheets(page).Range("F2").Value = currentRow(14)
                oBook.Worksheets(page).Range("A5").Value = currentRow(12)
                ...
                'Incremento la pagina
                page = page + 1
                'Se la pagina e' maggiore di 3 la devo creare
                If page > 3 Then

oBook.Worksheets.Add(After:=oBook.Worksheets(oBook.Worksheets.Count))
                End If

            Catch ex As Microsoft.VisualBasic.FileIO.MalformedLineException
                MsgBox("Line " & ex.Message & "is not valid and will be skipped.")
            End Try
        End While
        lblShowElab.Text = "Elaborazione Terminata"
    End Using
    'Salva il Workbook ed esce da Excel
    oBook.SaveAs("output.xlsx")
    oExcel.Quit()
End Sub
End Class

命令     oBook.Worksheets(page).Range(“B2”)。Borders(xlEdgeRight).LineStyle = xlContinuous     oBook.Worksheets(页面).Range(“B2”)。Borders(xlEdgeRight).Weight = xlThin 对我不起作用因为Visual Studio无法识别并标记xlEdgeRight,xlContinuous,xlEdgeRight,xlThin变量并假装我声明了这一点。

这个逗号在我在互联网上找到的每个例子都很常见,我不明白为什么不适合我。我是否错过了一些要声明的库或命名空间?我需要什么?

希望有人可以帮助我, 问候,非常重视。

1 个答案:

答案 0 :(得分:1)

所有常量如xlEdgeRight,xlContinuous,xlEdgeRight,xlThin等都只是长整数。

您需要查找其值并在应用程序中使用它们。

理想情况下,您需要在应用程序中创建一堆常量,以便继续使用命名版本,以便更容易理解代码。

以下页面列出了所有excel常量及其值。 http://www.smarterdatacollection.com/Blog/?p=374 我假设没有绑定到特定的Excel版本,但如果他们是你只需要查找你的版本。