Der folgende Code funktioniert für die erste Zeile der Tabelle, aber die Offset-Funktionen FX_Rate und FX_Date führen weiterhin zu Fehlern und die Offset-Funktionen Table_Date und Table_Rate funktionieren überhaupt nicht (alle jeweils) ElseIf für jede Währung). Kann mir bitte jemand sagen, was ich falsch mache? Ich habe das Gefühl, ich habe nur einige Offset-Funktionen in den falschen Bereichen des Codes, aber ich könnte weit weg sein.Fehler bei Offset-Funktionserstellung (VBA)
Der Code soll die Daten in der Tabelle übernehmen, ein Datum mit den FX-Informationen abgleichen und den Wechselkurs an diesem Tag zurückgeben, dann zum nächsten Eintrag in der Tabelle gehen, bis er eine leere Zelle erreicht.
Ich entschuldige mich, wenn das eine dumme Frage ist oder schon einmal gefragt wurde - ich konnte keine Antwort finden.
Sub Convert()
Dim Table_Date As Range
Set Table_Date = Range("B12")
Dim FX_Date As Range
Set FX_Date = Range("L11")
Dim Table_Rate As Range
Set Table_Rate = Range("E12")
Dim FX_Rate As Range
Set FX_Rate = Range("M11")
Dim Table_Currency As Range
Set Table_Currency = Range("D12")
Dim x As Integer
Dim y As Integer
x = 2
y = 2
Do While x > 1
If Table_Date = "" Then
x = -1
Else
If Table_Currency = "USD" Then
Do While y > 1
If Table_Date = FX_Date Then
Table_Rate = FX_Rate
y = -1
x = -1
Else
Set FX_Date = FX_Date.Offset(1, 0)
Set FX_Rate = FX_Rate.Offset(1, 0)
End If
Loop
Set Table_Date = Table_Date.Offset(1, 0)
Set Table_Rate = Table_Rate.Offset(1, 0)
ElseIf Table_Currency = "EUR" Then
Set FX_Rate = FX_Rate.Offset(0, 2)
Do While y > 1
If Table_Date = FX_Date Then
Table_Rate = FX_Rate
y = -1
x = -1
Else
Set FX_Date = FX_Date.Offset(1, 0)
Set FX_Rate = FX_Rate.Offset(1, 0)
End If
Loop
Set Table_Date = Table_Date.Offset(1, 0)
Set Table_Rate = Table_Rate.Offset(1, 0)
ElseIf Table_Currency = "JPY" Then
Set FX_Rate = FX_Rate.Offset(0, 1)
Do While y > 1
If Table_Date = FX_Date Then
Table_Rate = FX_Rate
y = -1
x = -1
Else
Set FX_Date = FX_Date.Offset(1, 0)
Set FX_Rate = FX_Rate.Offset(1, 0)
End If
Loop
Set Table_Date = Table_Date.Offset(1, 0)
Set Table_Rate = Table_Rate.Offset(1, 0)
ElseIf Table_Currency = "SGD" Then
Set FX_Rate = FX_Rate.Offset(0, 4)
Do While y > 1
If Table_Date = FX_Date Then
Table_Rate = FX_Rate
y = -1
x = -1
Else
Set FX_Date = FX_Date.Offset(1, 0)
Set FX_Rate = FX_Rate.Offset(1, 0)
End If
Loop
Set Table_Date = Table_Date.Offset(1, 0)
Set Table_Rate = Table_Rate.Offset(1, 0)
ElseIf Table_Currency = "HKD" Then
Set FX_Rate = FX_Rate.Offset(0, 6)
Do While y > 1
If Table_Date = FX_Date Then
Table_Rate = FX_Rate
y = -1
x = -1
Else
Set FX_Date = FX_Date.Offset(1, 0)
Set FX_Rate = FX_Rate.Offset(1, 0)
End If
Loop
Set Table_Date = Table_Date.Offset(1, 0)
Set Table_Rate = Table_Rate.Offset(1, 0)
ElseIf Table_Currency = "NZD" Then
Set FX_Rate = FX_Rate.Offset(0, 5)
Do While y > 1
If Table_Date = FX_Date Then
Table_Rate = FX_Rate
y = -1
x = -1
Else
Set FX_Date = FX_Date.Offset(1, 0)
Set FX_Rate = FX_Rate.Offset(1, 0)
End If
Loop
Set Table_Date = Table_Date.Offset(1, 0)
Set Table_Rate = Table_Rate.Offset(1, 0)
Else
Table_Rate = "Not a valid currency"
y = -1
x = -1
End If
End If
Loop
End Sub
ItI nicht verstehen, was Sie zu tun versuchen. Ein oder zwei Bilder könnten helfen. Aufgrund Ihrer allgemeinen Beschreibung habe ich das Gefühl, dass es eine viel einfachere Lösung gibt. –
@DougGlancy https://imgur.com/xJlcimb Das Makro soll Daten von links aufnehmen und die historischen Wechselkurse auf der rechten Seite verwenden, um den Betrag zu verdecken (im Moment versuche ich nur, die Rate zu erhalten, nicht die tatsächliche mathematische Umwandlung abschließen). – 1937827
Wie wäre es mit einem "SVERWEIS"? –