Grundsätzliches
Benutzerdefinierte Funktionen, also UDF, sind Funktionen, die man sich selbst im VBA-Editor erstellt. Dazu benennt man sie nicht mit Sub, sondern mit Function. Der Name der Funktion liefert dabei den Rückgabewert. Hei�t also eine Funktion "MeineFunktion(...)", schreibt man in die Zelle "=MeineFunktion(...)". Ebenfalls kann man Funktionen einsetzen, um durch Subs bestimmte Berechnungen durchführen zu lassen.
Beispiel: Eine Funktion, die immer das Datum zurückgibt, das in 14 Tagen liegt, Die Funktion braucht keine Parameter, sie wäre schlicht und einfach:
Function Datum_14Tage()
Datum_14Tage = Date + 14
End Function
Darauf können wir einfach per Sub zugreifen:
Sub Datumstest()
MsgBox Datum_14Tage
End Sub
Oder in die Zelle eingetragen:
=Datum_14Tage()
Ergebnisse/Rückgaben
Prinzipiell können benutzerdefinierte Funktionen alle möglichen Datentypen als Rückgabewerte haben: Strings, Zahlen, Datumsangaben usw. Selbst Arrays können Ergebnisse sein, die dann von anderen Subs verarbeitet werden.
Dynamische Arrayformeln/Matrixfunktionen
Seit Excel 365 ist es sogar möglich, Arrays als Ergebnisse solcher (dann Matrix-) Funktionen in Zellen eintragen zu lassen. Nehmen wir folgende Funktion als Beispiel, die für einen Monat eine kleine Liste mit Wochentagen und Kalenderwochen erstellt:
Function Monatstabelle(ByVal intMonatszahl As Integer, ByVal intJahr As Integer)
Dim datDatum As Date, arrS(), lngArr As LongPtr
datDatum = CDate("1." & intMonatszahl & "." & intJahr)
lngArr = 0
Do
lngArr = lngArr + 1
ReDim Preserve arrS(1 To 3, 1 To lngArr)
arrS(1, lngArr) = datDatum
arrS(2, lngArr) = Format(datDatum, "DDD")
arrS(3, lngArr) = Application.WorksheetFunction.IsoWeekNum(datDatum)
datDatum = datDatum + 1
Loop While Month(datDatum) = intMonatszahl
Monatstabelle = Application.WorksheetFunction.Transpose(arrS)
End Function
Sie erwartet als Parameter die Zahl des Monats und das Jahr. Wenn diese Angaben in D1 und in E1 stehen, können wir in der Tabelle diese Arrayformel eintragen:
=Monatstabelle(D1;E1)
Tipp nebenbei: Mit Transpose oder in deutscher Syntax MTRANS kann eingestellt werden, in welcher Richtung ein Array ausgegeben wird. Diese (eigentlich Tabellenblatt-) Funktion transponiert den Array, so dass dieser wahlweise über Spalten oder über Zeilen ausgegeben wird.
Formel übergelaufen
Beim ersten Verwenden einer Matrixfunktion (also nicht nur einer eigenen) erscheint die Meldung:
Formel übergelaufen - Ihre Formel hat mehrere Werte zurückgegeben, weshalb wir sie in die benachbarten leeren Zellen haben überlaufen lassen.
Diese Meldung besagt nichts anderes, als dass sich die Zelle mit der Formel nun verhält, wie man es in CSS mit float: left; beschreiben würde. Die Ergebnisse der Formel flie�en rechts und unterhalb von der Eingabezelle.
Mit dem Schnittmengenoperator @ nach dem Gleichheitszeichen können Sie übrigens einstellen, dass nur der erste Wert des Arrays in der Zelle erscheint.
Um zu gewährleisten, dass eine in einem Tabellenblatt eingesetzte UDF immer rechnet, sollte man an den Anfang der Funktion schreiben:
Application.Volatile