439
top 50 comments
sorted by: hot top controversial new old
[-] bulwark@lemmy.world 110 points 9 months ago

Man I hate VBA as much as the next guy, but when the IT department has your network so locked down you cant install anything. Having that hidden tab in Excel to write a script to automate some mundane task was really useful. I like python, but there's no fuckin way my ex employer would just allow me to run random python code like they did for VBA. It was a gov job btw.

[-] Willem@kutsuya.dev 50 points 9 months ago

Python is soon to be integrated into excel, I might not be a python fan but if it's gonna replace vba I'm all for it.

[-] Phen@lemmy.eco.br 54 points 9 months ago

It'll only run on cloud. Their employer would probably block that too.

[-] __ghost__@lemmy.ml 35 points 9 months ago

Afaik the python is ran on Microsoft servers, so not exactly a perfect solution. I doubt it will run offline at all

[-] aev@lemmy.sdf.org 10 points 9 months ago

Wouldn't it face the exact same security issues as VBA, with drive-by installs of obfuscated malware and executions of arbitrary code?

[-] geophysicist@discuss.tchncs.de 6 points 8 months ago

Can you not say that too loudly please

load more comments (2 replies)
[-] WaterWaiver@aussie.zone 9 points 8 months ago* (last edited 8 months ago)

The article is not about VBA, it's about VBS. The languages are similar but not the same (why exactly MS did it this way I'll never know).

VBA is for embedded macros in MS Office documents.

VBS is a standalone language you write into .vbs files that get executed by wscript.exe. It's a default windows feature that has been around a long time (IIRC the ILOVEYOU worm used it).

load more comments (1 replies)
[-] PlasmaDistortion@lemm.ee 101 points 9 months ago
[-] SamsonSeinfelder@feddit.de 36 points 9 months ago* (last edited 9 months ago)

It is their own Adobe Flash and it’s good that it is faded out. Too obscure in modern times, too many security flaws. Only warm nostalgic memories will remain in 10 years.

[-] MonkderZweite@feddit.ch 32 points 9 months ago

It is their own Adobe Flash

No, that was Silverlight. VBS is MS's JS.

[-] SamsonSeinfelder@feddit.de 9 points 9 months ago* (last edited 9 months ago)

While true it was their actual flash, based on install basis and history, silverlight was a blimp on MS history. While flash died slowly off after 2008 as html5 gained ground and plugins fell out of favor (anyone remember java applets?), MS decided to launch their own Plugin into a world that already turned away from this technologies. Classic MS.

The comparison that VBS is like MS JS is a bit wonky, as JS is breathing and alive, while VBS is not. You also never encounter VBS on a website.

load more comments (3 replies)
[-] Melkath@kbin.social 8 points 9 months ago

Some men just want to watch the world burn.

[-] AlmightySnoo@lemmy.world 67 points 9 months ago* (last edited 9 months ago)

I hope they kill off VBA too. I still see some teams in banks implementing Monte Carlo simulators or PDE solvers in straight VBA 🤢

[-] Dave@lemmy.nz 112 points 9 months ago

I have seen critical enterprise applications run in VBA in excel. Removing VBA would cause global economic ruin. I'm pretty sure that's the unspoken backstory for the Fallout series.

[-] Pistcow@lemm.ee 44 points 9 months ago

Can confirm. Worked at several billion dollar corps that would collapse without vba.

[-] dill@lemmy.one 22 points 9 months ago

Can confirm as well. It's wild

[-] Dee@lemmings.world 11 points 9 months ago

Another Sys Admin confirming that yes, the finance department runs nearly entirely on VBA. They would be lost without it.

load more comments (1 replies)
[-] OldFartPhil@lemm.ee 39 points 9 months ago* (last edited 9 months ago)

Another confirmation here. At my previous job, I was they guy who built Access databases and wrote VBA code. While not ideal, it was a very small business (less than 10 employees) and it was fit for purpose.

When I got a new job at a company with almost 3,000 employees, I was like, "Finally, I'll be working somewhere that has proper IT resources." Ha! I soon find out that my department runs critical business infrastructure with Excel macros. And we have a proper IT department.

As everyone has already said, if IT resources are in short supply (or the wait is too long, or building projects with IT support is a PITA), then people will build systems with the tools they have at hand. And that's often MS Office.

[-] Melkath@kbin.social 22 points 9 months ago* (last edited 9 months ago)

Also remember, strictly speaking, IT is not software development. IT is networking and hardware management.

Software development (and scoff all you want, but VBS/VBA are programming languages/frameworks used to develop software applications) is its own separate beast.

They MAY report to the CIO. They could also report to the COO. Fuck, software development/process automation/business intelligence can have a director reporting directly to the CEO.

In general, software development and information technology are not the same and don't reside in the same chain of command.

[-] HumbertTetere@feddit.de 11 points 9 months ago

Strictly speaking, information technology encompasses software dev as a subfield. Practically, a large software development at a company has very different needs and strategic goals than what people usually understand as the "IT guys" so what you mentioned. So they are set up accordingly in an organisation.

load more comments (1 replies)
load more comments (4 replies)
[-] Melkath@kbin.social 27 points 9 months ago

My job is literally to keep a NASDAQ company afloat on process automation written mostly in VBA to make up for the sweeping layoffs that were made to keep the CEOs bonuses fat...

[-] skeezix@lemmy.world 11 points 9 months ago

That type of bonus is usually called a “bone us”

load more comments (1 replies)
[-] HidingCat@kbin.social 20 points 9 months ago

WTF, seriously? VBA feels more like a scripting addon (which I suppose it is), not something to build wholesale CRITICAL programs with.

[-] Dave@lemmy.nz 25 points 9 months ago

They didn't start out building an enterprise critical application, they normally started as some little script someone built to make their work faster. Then they shared it with the team, built more features, and 20 years later hundreds of staff are using it and if it dissappeared they would be screwed.

Plus the data in them is often the only record of critical data (in their defense, the spreadsheets are typically stored somewhere where the backup process will back them up).

[-] cm0002@lemmy.world 13 points 9 months ago

they normally started as some little script someone built to make their work faster.

It's me, I'm that guy lmfao, although by the time I left it was considerably more complex. I have "real" languages under my belt, but it was a banking environment and VBA was all I had (Which even that kinda surprised me lol).

I was hooked into the windows API and doing all sorts of stuff and yea before leaving I did distribute stand alone parts of it (The full system was a beast, 90% of my job was automated towards the end lololol)

Honestly, VBA is more powerful than people give it credit for, just a PITA to implement some things

[-] magic_lobster_party@kbin.social 12 points 9 months ago

Nothing is more permanent than a temporary solution

[-] macallik@kbin.social 15 points 9 months ago* (last edited 9 months ago)

At my old job, we had a VBA script that would:

  1. Pull client data from SQL
  2. Load data into an Excel file
  3. Update charts and KPIs
  4. Copy/Paste chart and KPIs into PowerPoint
  5. Switch to the next client
  6. Repeat steps 1-5 for +100 clients

Thirty page custom reports per client within 2 minutes (when nothing broke). It allows you to interact and automate across the Microsoft Suite. That is one of the reasons why it is indispensable to many companies

load more comments (1 replies)
[-] kubica@kbin.social 14 points 9 months ago

The things done in excel might not be critical per-se, but macros are used and abused a lot and many companies can be affected by their dependence on workflows refined over the years.

load more comments (2 replies)
[-] Melkath@kbin.social 12 points 9 months ago

It's a scripting language.

A solid, verbose, diverse scripting language that gives you impressive control over Windows environments.

If some people are delivering malware or phishing, that sucks, but it doesn't negate the languages merit.

It would be the same as ceasing production of spray paint because of taggers.

The ends don't justify the means.

load more comments (1 replies)
[-] I_Miss_Daniel@kbin.social 5 points 9 months ago

I suppose Microsoft Access has better options now you can define the steps in macros, but I think it's still needed for many of the more fiddly bits.

load more comments (1 replies)
[-] MelodiousFunk@kbin.social 14 points 9 months ago

I have seen critical enterprise applications run in VBA in excel.

I wrote one of them. It replaced periodically writing down application outputs on paper and sounding the alarm if something went pear-shaped. It wasn't my job to develop software but I didn't want hand cramps to be my job, either. I had vague ideas about how to do what I wanted to do with Excel so I poked at it and googled until it worked. More than a decade later, I'm no longer there but that freakin spreadsheet is still running 24/7, being proudly showed off during tours of the facility.

I will cackle if MS ever pulls the plug on VBA.

[-] Dave@lemmy.nz 12 points 9 months ago

Your story is pretty typical in my experience. No one hires a dev team to build a VBA tool (except the occasional MS Access tool). It's normally someone doing the work who works out how to do a basic macro to make it quicker, and it grows from there.

[-] MelodiousFunk@kbin.social 8 points 9 months ago* (last edited 9 months ago)

Indeed. In my case, I fought through managerial malaise and turned the entire process on its ear. But even after the approach proved its worth, they refused to put a dev resource on it. It became my problem 24/7.

Remember kids, being good at something outside of your job description means it's now your job. If the boss refuses to compensate you for it, slap it on your resume and find someone who will.

load more comments (1 replies)
[-] MonkderZweite@feddit.ch 9 points 9 months ago* (last edited 9 months ago)

MS: You have until (now +2 years) to phase out VBA.

Enterprise: panic noises

[-] Diplomjodler@feddit.de 12 points 9 months ago* (last edited 9 months ago)

Nah. They'll just sit on their hands for two years and then panic.

load more comments (1 replies)
[-] brsrklf@jlai.lu 9 points 9 months ago* (last edited 9 months ago)

I've worked for a major international company and I was for a while the only maintainer of a shitty request form in an excel file, sent worldwide to hundreds of people. As they wanted more and more specific functions the stuff grew to thousands of unholy VBA code lines and a huge hidden sheet of data.

That thing even had a fully custom language switch function for all dozens of field labels and their possible values.

I kinda hope they're still using it (that wouldn't surprise me) and that their whole workflow will crash and burn when Microsoft finally kills VBA.

[-] aev@lemmy.sdf.org 6 points 9 months ago

Enterprise will cause a boom in hiring VBA devs to migrate legacy apps to other programming languages, then hear Microsoft will extend support for a few more years, then fire all those VBA devs again. If Microsoft had some wits, they'd create easy tools to migrate VBA to C#.

load more comments (3 replies)
[-] driving_crooner@lemmy.eco.br 24 points 9 months ago

I'm migrating some VBAs to python/pandas and reducing some process times from half an hour to 3 minutes.

[-] AlmightySnoo@lemmy.world 19 points 9 months ago

Yup that's normal because VBA is single-threaded, doesn't take advantage of vector instructions and even its interpreter is slow. So when someone writes numerical code in VBA working in single precision, and assuming they have an 8 core CPU with AVX2, they're using only 1/64-th of their CPU's processing power. On the other hand with Python, while it's still interpreted, the interpreter is much faster on its own, and you have modules like numpy that use precompiled routines that take advantage of vector instructions (and possibly multiple cores).

load more comments (11 replies)
load more comments (3 replies)
[-] MooseBoys@lemmy.world 53 points 9 months ago* (last edited 9 months ago)

The first hack I ever did was to remove the security add-on my middle school put on our macs so we couldn’t play games. The attack vector was the file APIs in VBScript executed via a word doc. Fun times!

[-] PoolloverNathan@programming.dev 5 points 8 months ago

At least you got hardware that wasn't designed for schools.

load more comments (1 replies)
[-] cesium@sh.itjust.works 25 points 9 months ago

Took them long enough.

[-] Raxiel@lemmy.world 19 points 8 months ago

What if law enforcement need to make a gooey to trace a hacker?

[-] esc27@lemmy.world 12 points 8 months ago

Hopefully this means a modern replacement for slmgr.vbs

[-] soggyoreo@lemmy.world 7 points 8 months ago

It's okay, we will have python as a replacement.

load more comments
view more: next ›
this post was submitted on 11 Oct 2023
439 points (98.9% liked)

Technology

55692 readers
2717 users here now

This is a most excellent place for technology news and articles.


Our Rules


  1. Follow the lemmy.world rules.
  2. Only tech related content.
  3. Be excellent to each another!
  4. Mod approved content bots can post up to 10 articles per day.
  5. Threads asking for personal tech support may be deleted.
  6. Politics threads may be removed.
  7. No memes allowed as posts, OK to post as comments.
  8. Only approved bots from the list below, to ask if your bot can be added please contact us.
  9. Check for duplicates before posting, duplicates may be removed

Approved Bots


founded 1 year ago
MODERATORS