我目前在VBA中使用此函数来获取已关闭工作簿中单元格的值。我想使用类似的过程将单元格的值设置为我想要的任何内容,而无需打开文件。这可能吗?
Private Function GetValue(path, file, sheet, ref)
Dim arg As String
If Right(path, 1) <> "\" Then path = path & "\"
If Dir(path & file) = "" Then
GetValue = "File Not Found"
Exit Function
End If
arg = "'" & path & "[" & file & "]" & sheet & "'!" & _
Range(ref).Range("A1").Address(, , xlR1C1)
GetValue = ExecuteExcel4Macro(arg)
End Function
答案 0 :(得分:4)
是的,您可以使用ADO作为Gary评论,但前提是您的Excel工作表安排在类似数据库的结构中。
这意味着您将有效字段排列在列中(带或不带标题)
例如:
现在,您看到ID号 12345 的名称为 John John ,您希望将其更新为 John Knight 。
使用ADO,您可以尝试:
编辑1:您实际上可以在不使用 Recordset 的情况下执行此操作。见下面的更新。
Sub conscious()
Dim con As ADODB.Connection
Dim sqlstr As String, datasource As String
Set con = New ADODB.Connection
datasource = "C:\Users\UserName\Desktop\TestDataBase.xlsx" 'change to suit
Dim sconnect As String
sconnect = "Provider=Microsoft.ACE.OLEDB.12.0;" & _
"Data Source=" & datasource & ";" & _
"Extended Properties=""Excel 12.0;HDR=YES"";"
With con
.Open sconnect
sqlstr = "UPDATE [Sheet1$] SET [Name] = ""John Knight"" WHERE [ID Number] = 12345"
.Execute sqlstr
.Close
End With
Set con = Nothing
End Sub
<强>结果:强>
我不完全确定这是否是你想要的但HTH。
注意:
编辑1:如果您的文件没有标题
,这是怎么做的首先将连接字符串 HDR 参数更改为否 :.
sconnect = "Provider=Microsoft.ACE.OLEDB.12.0;" & _
"Data Source=" & datasource & ";" & _
"Extended Properties=""Excel 12.0;HDR=NO"";"
然后将您的SQL字符串调整为:
sqlstr = "UPDATE [Sheet1$] SET F2 = ""John Knight"" WHERE F1 = 12345"
因此字段1 为F1
,字段2 等为F2
。