Install both Chocolatey and Scoop. (I just put the "vs." in there as clickbait.) They make installing and managing software on Windows so much easier. They are different tools, though, and I suggest that their usage depends on the scenario.
In the Linux world, there are
pacman, and many others. In Mac and Linux, there is
brew. For Windows, there are two:
scoop. They manage software from the PowerShell command-line. (So... there is also winget. It may soon be a worthy addition to this article.)
For both of these tools, you will need to set the PowerShell Execution Policy to something more permissive than "Restricted." Here is my suggestion: be strict with the scope of LocalMachine, and only slightly more permissive with the CurrentUser scope. So, first launch PowerShell as Admin (I use ⊞-x then select "Windows PowerShell (Admin)") and run
Set-ExecutionPolicy AllSigned Set-ExecutionPolicy RemoteSigned -scope CurrentUser
The first line means that all scripts and configuration files on this computer must be signed by a trusted publisher, even if you write them yourself. This is pretty strict.
The second line means that all scripts and configuration files downloaded from the Internet must be signed by a trusted publisher, but scripts you write yourself will work, for the current user. This policy will "win" when you are logged in.
Chocolatey: conventional install locations, as Admin
Chocolatey can install from a community repository with thousands of packages. In general, installing one of these packages, such as Google Chrome, will require elevated Admin privileges, and will install it where you would expect (likely
C:\Program Files\ or
C:\Program Files (x86)\). The applications will have shortcuts in your start menu, and possibly on your desktop.
In an Admin-level PowerShell window, the following should work, provided you have set the ExecutionPolicy as above:
iwr -useb chocolatey.org/install.ps1 | iex
See the detailed installation docs if you have issues with the above.
choco search ditto
choco install ditto
choco upgrade all
Scoop: non-Admin by default, installs in user directory
Scoop is designed for developers who have an affinity for Unix. By default, it installs packages to
~/scoop/ and this is both a strength and a confusion point. Apps will not by default show in the start menu, and if plugins or addons expect to find the installation in a certain directory (looking at you, OBS Studio!), there will be some inconvenience and tedious setup.
If you do not have Admin access to your system (for instance, this is a shared server with Remote Desktop access), then Scoop is the right choice.
Scoop also seems natural for installing command-line tools that you might miss from Unix-like systems, such as Linux or Mac. While some of these tools may be available through Chocolatey, the Scoop ecosystem is designed with such tools in mind.
The Scoop wiki has a nice write-up comparing Scoop and Chocolatey.
In any PowerShell window, no Admin necessary, the following will install Scoop, provided you have set the ExecutionPolicy as detailed at the beginning of the article:
iwr -useb get.scoop.sh | iex
See the detailed installation docs for more info.
I often install the extras bucket immediately:
scoop bucket add extras
A bucket is a set of apps that can be searched and installed. To see all the known community buckets:
scoop bucket known
Then add the ones you like!
scoop search sudo
scoop install sudo
scoop upgrade *
Enjoy and experiment!