

Visual Basic - odovzdávanie argumentov hodnotou
Ahoj, prosím o poradenie, čo robím zle:
volám procedúru Zobraz, pričom do nej odovzdávam hodnotu "Bratislava":
Sub Pokus()
Zobraz ("Bratislava")
End Sub
hodnotu "Bratislava" preberám do procedúry Zobraz ako premennú Mesto:
Sub Zobraz(Mesto)
MsgBox Mesto
End Sub
Zatiaľ to ide, ale keď chcem odovzdať dve hodnoty, pripravím procedúru Zobraz nasledovne:
Sub Zobraz(Mesto1, Mesto2)
MsgBox Mesto1
MsgBox Mesto2
End Sub
ale pri volaní:
Sub Pokus()
Zobraz ("Bratislava", "Košice")
End Sub
mi Visual Basic označí riadok Zobraz ("Bratislava", "Košice") červenou sa dá hlášku : Compile Error, Expected: =
pričom nechápem, kde sa očakáva "=" a čím ďalej doplniť, keďže pri jednom argumente poslúchal bez odvrávania ;)
VBA nepodporuje overloading funkcí v takové podobě, jaká je známá u pokročilejších jazyků. Nicméně nějaká řešení se taky najdou:
http://stackoverflow.com/questions/64436/function- overloading-and-udf-in-excel-vba
ďakujem, niečo som z toho, čo som pochopil dedukciou, odskúšal, zatiaľ bezvýsledne, ale nejde mi do hlavy, prečo by nemalo fungovať odovzdávanie viacerých argumentov... Stále sa mi zdá, že na základe voľakedy čítaného (bohvie kde) by to malo ísť a či nie je len problém v syntaxe...
Více argumentů funguje. Nefunguje, když tam máš více stejně pojmenovaných funkcí.
OK, z toho tvého popisu to tak ale vypadalo.
Zkus to volat takhle:
Jupííííí, máš pusu na čelo!!!
Tak to sa divím... predávané hodnoty sa nevymenovávajú v zátvorkách?!?!
DÍKY MOOOC!!!
Díky moc klucí,
trápilo mě to dlouho a úplně náhodou jsem narazil na vaše příspěvky. Taky jsem nevěděl jak předat dva a více parametrů a jde jen o takovou blbost a to, nedát to do závorek.. :D