1

我正在编写一个宏来检查一个值是否为真,如果是,则获取该行的第一个单元格并存储它。例如:

|191|c:users\public\test.dbf |真 |  
|192|c:users\public\test2.dbf |假|  
|193|c:users\public\test2.dbf |假|

我想遍历这个数组,当一个值为 True 时,我需要存储 191 和 c:users\public\test.dbf (对于这个例子;要存储的实际值将取决于行)。

这是我的代码:

For Each strPath In Worksheets("OPTIONS").Range("F2:H6")
    newChemin = strPath
    If strPath <> True And strPath <> False Then Chemin = strPath

    If strPath.Value = "True" Then
        For Each Cell In Worksheets("OPTIONS").Range("F2:F6")
            If Cell = Chemin Then
                strChemin = Chemin
                Exit For
            End If
        Next Cell

        Set wsSheet1 = wbBook.Worksheets("DB" & strChemin)        
        If strPath.Value = "TRUE" Then
            If FichierExiste(Chemin) Then
                Line = Line + 1
            Else
                Chemin = Worksheets("OPTIONS").Cells(7, 7).Value & "\" & strChemin & "\ancretbd.mdb"
                If FichierExiste(Chemin) Then
                    '* Appel de la Method mod_Importation
                    Call Importation_Totale
                Else
                    MsgBox "Desolé, le fichié demandé n'existe pas !"
                End If
            End If
        End If
    End If
Next strPath
4

2 回答 2

1

由于法语 (??) 变量,很难理解这段代码在做什么。如果您可以描述什么是 chemin,则可能更容易理解您指的是行的哪一部分。

但是,由于您的 strPath 实际上是一个 Range,您可以简单地参考它的偏移量!

For Each strPath In Worksheets("OPTIONS").Range("F2:H6")
    If strPath.Value = "True" Then
        Set wsSheet1 = wbBook.Worksheets("DB" & strPath.Offset(0, -1).Value
        If FichierExiste(strPath.Offset(0, -2).Value) Then
        Line = Line + 1
        Else
            Chemin = Worksheets("OPTIONS").Cells(7, 7).Value & "\" & strChemin & "\ancretbd.mdb"
            If FichierExiste(Chemin) Then
                 '* Appel de la Method mod_Importation
                 Call Importation_Totale
            Else
                MsgBox "Desolé, le fichié demandé n'existe pas !"
            End If
        End If
    End If
Next strPath

这可能不是 100% 正确(因为我不清楚代码的功能),并且偏移量可能是错误的(上例中的 -1 和 -2)。但我希望这能给你一个解决问题的想法!

于 2012-11-06T15:13:11.557 回答
0

在我看来,H 列是包含 TRUE 或 False 的列。在这种情况下,如果您只想检查此列并相应地更新列 F 和 G,那么这个简化的代码可以为您完成这项工作:

For Each strPath In Worksheets("OPTIONS").Range("H2:H6")
     If strPath.Value = "True" Then
         Range("F" & strPath.Row).Value = "191"
         Range("G" & strPath.Row).Value = "c:users\public\test.dbf"

     End If
Next
于 2012-11-06T15:27:36.523 回答