Reputation: 797
I need to do a software audit of more than 300 computers that are neither on the same network, or owned by the same company.
Is there an command or small program (that can be run without installing) that I can email to the end-users to run that will output the MS Windows and MS Office versions?
Upvotes: 8
Views: 68374
Reputation: 1
@echo off
SetLocal EnableExtensions
SetLocal EnableDelayedExpansion
for /f "delims=" %%a in ('"wmic OS get Caption /value|find "^=""') do set "%%a"
for /f "tokens=3 delims=." %%a in ('reg query "HKEY_CLASSES_ROOT\Word.Application\CurVer"') do set reg=%%a
set /a i=0
for %%b in (11 12 14 15 16) do (
if %%b == %reg% goto setver
set /a i+=1
)
:setver
set /a n=0
for %%c in (2003 2007 2010 2013 2016-2019-2021-365) do (
if !n! == !i! set ver=%%c&& goto endloop
set /a n+=1
)
:endloop
if exist "%PROGRAMFILES(X86)%" (set winbit=64) else (set winbit=86)
goto %winbit%
:64
if exist "%PROGRAMFILES%\Microsoft Office" (set offbit=64)
if exist "%PROGRAMFILES(X86)%\Microsoft Office" (set offbit=86)
goto result
:86
if exist "%PROGRAMFILES%\Microsoft Office" (set offbit=86)
:result
echo %Caption:~,-1% x%winbit%-bit
echo Microsoft Office %ver% x%offbit%-bit
pause
Upvotes: 0
Reputation: 2791
I'm not here for detecting Windows Version, I feel like thats well covered in other answers and should have been a separate question. But, Office is the trick one IMO. Here is how I detect MS Office Version & Arch.
Note: This is barely tested on two x32 bit different installations, but "should" catch them all.
@ECHO OFF
CLS
setlocal enableextensions enabledelayedexpansion
::FreeSoftwareServers.com
set key="*0FF1CE*"
set threesixtyfivekey="O365*"
set keypath=
set arrsize=1
set arg[0]="HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall"
set arg[1]="HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\Windows\CurrentVersion\Uninstall"
for /l %%n in (0,1,%arrsize%) do (
FOR /F "tokens=* USEBACKQ" %%N IN (`REG QUERY !arg[%%n]! /f %threesixtyfivekey% /k 2^>nul`) DO (
ECHO "%%N" | FIND /I "HKEY">Nul && (
If %%n == 0 (
set arch=x32
) ELSE (
set arch=x64
)
set keypath=%%N
goto keypathFound
)
)
FOR /F "tokens=* USEBACKQ" %%N IN (`REG QUERY !arg[%%n]! /f %key% /k 2^>nul`) DO (
ECHO "%%N" | FIND /I "HKEY">Nul && (
If %%n == 0 (
set arch=x32
) ELSE (
set arch=x64
)
set keypath=%%N
goto keypathFound
)
)
)
GoTo end
:keypathFound
FOR /F "skip=2 tokens=1,2* USEBACKQ" %%N IN (`reg query "%keypath%" /t REG_SZ /v "DisplayName"`) DO (
IF /I "%%N" == "DisplayName" (
SET OVer=%%P%~1
GoTo Found
)
)
:Found
for /f "tokens=1-20 delims=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$&*()-= " %%a in ("%OVer%") do (
IF %%a == 64 (
set ONum=%%b
GoTo varset
)
IF %%a == 32 (
set ONum=%%b
GoTo varset
)
set ONum=%%a
)
:varset
Echo Office Number: %ONum%
ECHO Office Display Name: %OVer%
ECHO Software Architecture: %arch%
PAUSE
:End
Upvotes: 0
Reputation: 11
To get the office version under Windows 10, this is quite elegant:
for /F "tokens=3 delims=." %%O in ('reg query HKEY_CLASSES_ROOT\Word.Application\CurVer') do set _officeVer=%%O
Does not require admin rights and works also on xp and above
Upvotes: 1
Reputation: 2815
One possible way of obtaining the current Windows Version and Microsoft Office version is to query the system registry entries using command line.
To get the windows version using System registry , use the following command:
reg query "HKLM\Software\Microsoft\Windows NT\CurrentVersion" /v "ProductName"
This will give an output which can be parsed to get the current windows version/name.
To get the current office version , use:
reg query "HKEY_CLASSES_ROOT\Word.Application\CurVer"
The output of this command gives the office version in number format such as 14, 15, etc.
Parse the output to get the version number and match against the list of existing Microsoft office versions to get the name of the version installed:
Office 97 - 7.0
Office 98 - 8.0
Office 2000 - 9.0
Office XP - 10.0
Office 2003 - 11.0
Office 2007 - 12.0
Office 2010 - 14.0
Office 2013 - 15.0
Office 2016 - 16.0
Hope this helps!!
Upvotes: 18
Reputation: 7095
And 1 more using npocmaka's code but adding in a map to make it more user friendly:
@echo off
setlocal
call :GetOfficeVer
endlocal
exit /b
:GetOfficeVer
::@echo off
setlocal enableDelayedExpansion
for /f "tokens=2 delims==" %%O in (
'ftype ^|findstr /r /I "\\OFFICE[0-9]*" 2^>nul') do (
set "verp=%%~O"
goto :end_for
)
:end_for
for %%P in (%verp%) do (
set "off_path=%%~dpP"
for %%V in ("!off_path:~-3,2!") do (
set "off_ver=%%~nV"
call :Map !off_ver! && exit /b
)
)
:Map
set "v=%1"
set "map=11-2003;12-2007;14-2010;15-2013"
call set v=%%map:*%v%-=%%
set v=%v:;=&rem.%
echo Microsoft Office Version: %v%
endlocal
exit /b
Upvotes: 1
Reputation: 11
I use this to grab version 2003, 2007, 2010 and 2013.
@echo off
setlocal enabledelayedexpansion
for /f "tokens=3 delims=." %%a in ('reg query "HKEY_CLASSES_ROOT\Word.Application\CurVer"') do set reg=%%a
set /a i=0
for %%b in (11 12 14 15) do (
if %%b == %reg% goto setver
set /a i+=1
)
:setver
set /a n=0
for %%c in (2003 2007 2010 2013) do (
if !n! == !i! set ver=%%c && goto endloop
set /a n+=1
)
:endloop
echo Microsoft Version: %ver%
echo.
endlocal
:end
pause
Upvotes: 1
Reputation: 57252
@echo off
setlocal enableDelayedExpansion
for /f "tokens=2 delims==" %%O in ('ftype ^|findstr /r /I "\\OFFICE[0-9]*" 2^>nul') do (
set "verp=%%~O"
goto :end_for
)
:end_for
for %%P in (%verp%) do (
set "off_path=%%~dpP"
for %%V in ("!off_path:~0,-1!") do (
set "office_version=%%~nV"
goto :end_for2
)
)
:end_for2
echo %office_version%
endlocal
does NOT require administrator permissions and works on Windows XP and above
Upvotes: 2