{"id":438,"date":"2011-01-03T15:48:54","date_gmt":"2011-01-03T14:48:54","guid":{"rendered":"http:\/\/www.matjazev.net\/blog\/?p=438"},"modified":"2011-01-09T12:52:53","modified_gmt":"2011-01-09T11:52:53","slug":"razvoj-dodatkov-za-excel","status":"publish","type":"post","link":"https:\/\/www.matjazev.net\/blog\/2011\/01\/03\/razvoj-dodatkov-za-excel\/","title":{"rendered":"Razvoj dodatkov za Excel"},"content":{"rendered":"<p>Ko razvijamo dodatke za Excel se prej ali slej <strong>sre\u010damo s problemom vzdr\u017eevanja programske kode<\/strong>. Na izbiro imamo namre\u010d kar nekaj razli\u010dnih na\u010dinov in okolij za razvoj dodatkov.<\/p>\n<p>Na eni strani imamo VBA, ki je vgrajen v ve\u010dino Office produktov, na drugi strani imamo programski jezik C in WIN API ter COM, na tretji pa .NET tehnologijo in COM.<\/p>\n<p><a href=\"http:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj1.gif\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-439\" title=\"Office_razvoj1\" src=\"http:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj1.gif\" alt=\"\" width=\"380\" height=\"383\" srcset=\"https:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj1.gif 380w, https:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj1-150x150.gif 150w, https:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj1-297x300.gif 297w\" sizes=\"(max-width: 380px) 100vw, 380px\" \/><\/a><\/p>\n<h2>VBA<\/h2>\n<p><strong>Vsekakor je se potrebno pred kakr\u0161nimkoli resnim razvojem za MS Office dodobra seznaniti z programskim jezikom VBA<\/strong>. Razvoj v VBA-ju je nekako najla\u017eji izmed vseh na\u010dinov in ima mnogo prednosti:<\/p>\n<table>\n<tbody>\n<tr>\n<td valign='top'>\n<h3>VBA Prednosti<\/h3>\n<ul>\n<li>VBA bazira na programskem jeziku BASIC, ki je zelo preprost jezik<\/li>\n<li>Zelo dobra podpora znotraj vseh Office programov<\/li>\n<li>Vve\u010dino problemov nam re\u0161i vgrajeno snemanje makrov \u2013 \u010de \u017eelite kaj postoriti, za\u010dnete s snemanjem makra in ga nato razvijate dalje<\/li>\n<li>VBA urejevalnik nam preko vgrajenega &#8216;InteliSence&#8217;-a aktivno in obilno pomaga pri programiranju.<\/li>\n<li>Programska koda se ne prevaja, temve\u010d interpretira, kar je za razvoj dobrodo\u0161lo, saj lahko programsko kod spreminjamo med razhro\u0161\u010devanjem programa (glej spodaj)<\/li>\n<\/ul>\n<\/td>\n<td valign='top'>\n<h3>VBA Slabosti<\/h3>\n<ul>\n<li>Programska koda je zapakirana v posamezen dokument (Excelov XLS ali XLSM oz. XLA in XLAM) kar pomeni slab nadzor nad programsko kodo<\/li>\n<li>Programske kode ni mo\u017eno dajati v repozitorije programske kode<\/li>\n<li>Ote\u017eena je souporaba kode v ve\u010d projektih saj VBA ne pozna koncepta knji\u017enic<\/li>\n<li>Programska koda se ne prevaja temve\u010d interpretira (glej zgoraj), kar je lahko slabost, saj se ob prevajanju odkrijejo mnoge napake.<\/li>\n<li>Preko VBA ne moremo storiti vsega \u2013 dolo\u010dene stvari lahko spreminjamo, popravljamo, dograjujemo samo preko knji\u017enic v C oz. C++ jezikih.<\/li>\n<\/ul>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2>C \/ C++<\/h2>\n<p><strong> Izmed vseh izbir je to najte\u017eja pot, ki ima glede na naslednjo mo\u017enost, torej razvoj v .NET-u eno slabost in eno prednost<\/strong><\/p>\n<table>\n<tbody>\n<tr>\n<td valign='top'>\n<h3>C \/ C++ prednosti<\/h3>\n<ul>\n<li>Najhitrej\u0161a koda in najve\u010dja mo\u017enost nadzora nad na\u010dinom izvajanja<\/li>\n<\/ul>\n<\/td>\n<td valign='top'>\n<h3>C \/ C++ slabosti<\/h3>\n<ul>\n<li>Zelo zapleten in dolgotrajen razvoj, slaba (zelo slaba!) literatura<\/li>\n<\/ul>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h2>.NET<\/h2>\n<p><strong> Za razvoj v .NET-u pa imamo ve\u010d mo\u017enosti, ki so prikazane spodaj.<\/strong><\/p>\n<p><a href=\"http:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj2.gif\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-451\" title=\"Office_razvoj2\" src=\"http:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj2.gif\" alt=\"\" width=\"380\" height=\"264\" srcset=\"https:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj2.gif 380w, https:\/\/www.matjazev.net\/blog\/wp-content\/uploads\/2011\/01\/Office_razvoj2-300x208.gif 300w\" sizes=\"(max-width: 380px) 100vw, 380px\" \/><\/a><\/p>\n<table>\n<tbody>\n<tr>\n<td valign='top'>\n<h3>.NET Prednosti<\/h3>\n<ul>\n<li>Mo\u017ena uporaba knji\u017enic<\/li>\n<li>Mo\u017ena uporaba vseh znanj pridobljenih na podro\u010dju \u2013NET razvoja vklju\u010dno z tisi\u010di in tiso\u010di objektov, ki so napisani zanj<\/li>\n<li>Glede na prej\u0161njo to\u010dko seveda tudi preprosta mo\u017enost povezav do podatkovnih baz, spletnih storitev\u2026<\/li>\n<li>Popoln nadzor nad programsko kodo in mo\u017enost uporabe repozitorijev programske kode<\/li>\n<\/ul>\n<\/td>\n<td valign='top'>\n<h3>.NET Slabosti<\/h3>\n<ul>\n<li>Neintuitivni razvoj<\/li>\n<li>Te\u017eak dostop do ustrezne literature za dostop do Office automatization objektov<\/li>\n<\/ul>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n","protected":false},"excerpt":{"rendered":"<p>Ko razvijamo dodatke za Excel se prej ali slej sre\u010damo s problemom vzdr\u017eevanja programske kode. Na izbiro imamo namre\u010d kar nekaj razli\u010dnih na\u010dinov in okolij za razvoj dodatkov. Na eni strani imamo VBA, ki je vgrajen v ve\u010dino Office produktov, na drugi strani imamo programski jezik C in WIN API ter COM, na tretji pa &hellip; <a href=\"https:\/\/www.matjazev.net\/blog\/2011\/01\/03\/razvoj-dodatkov-za-excel\/\" class=\"more-link\">Continue reading <span class=\"screen-reader-text\">Razvoj dodatkov za Excel<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[18,3,35,34],"tags":[36,14,22,30],"_links":{"self":[{"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/posts\/438"}],"collection":[{"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/comments?post=438"}],"version-history":[{"count":14,"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/posts\/438\/revisions"}],"predecessor-version":[{"id":469,"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/posts\/438\/revisions\/469"}],"wp:attachment":[{"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/media?parent=438"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/categories?post=438"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.matjazev.net\/blog\/wp-json\/wp\/v2\/tags?post=438"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}