从批处理文件运行PS1文件,在拇指驱动器上运行同一文件夹

时间:2020-10-15 15:33:56

标签: powershell batch-file drive ps1

诚然,我不是脚本编写者。我拼凑了已经起作用但尝试学习的东西。

我有一个脚本,需要大量的体力劳动来为自己和我们的技术人员设置扫描用户。这是一小部分作为批处理文件编写的文件。在暂停之前的最后,我想调用PowerShell以显示什么是网络类型,而不是对其进行更改。至少目前还没有。我确实从文件中删除了很多多余的东西以节省空间。批处理文件和PS1文件都将位于拇指驱动器上的同一文件夹中。

nettype.ps1文件仅具有:

get-netconnectionprofile
pause

当然可以暂停一下,以便技术人员可以看到网络类型。

希望有人有一个简单的解决方案。我确实看过这里和其他网站。我可能在搜索或理解需要做的事情时使用的术语不正确。

net user Scans Scanner1 /add
net localgroup administrators Scans /add
wmic UserAccount where Name='Scans' set PasswordExpires=False
md C:\Scans
@echo off

NET SHARE Scans=C:\Scans /Grant:Scans,Full
ICACLS "C:\Scans" /Grant Scans:(OI)(CI)(F) /t /c
ICACLS "C:\Scans" /Grant Everyone:(OI)(CI)(F) /t /c
netsh advfirewall firewall set rule group="Network Discovery" new enable=Yes
netsh advfirewall firewall set rule group="File and Printer Sharing" new enable=Yes
PowerShell.exe -File "nettype.ps1"
pause

3 个答案:

答案 0 :(得分:1)

我找到了答案,知道这很简单。

只需在批处理文件中使用以下内容:

powershell.exe -ExecutionPolicy Bypass -File ""%~dp0nettype.ps1""

答案 1 :(得分:1)

您可以将powershell调用更改为以下内容,以在同一目录中找到ps1文件:

powershell.exe -File "%~dp0nettype.ps1" 

%~dp0%0变量以及~d~p修饰符的组合。

  • %0是当前批处理文件的完整路径。
  • ~d%0(例如%~d0)结合使用时,将从%0中获得驱动器字母部分(例如C:)。
  • ~p%0(例如%~p0)结合使用时,将获得%0的路径部分而没有文件名。
  • %~dp0组合在一起,将为您提供当前批处理文件所在文件夹的完整路径。

您可以在这里找到这些修饰符的完整列表:https://docs.microsoft.com/en-us/previous-versions/windows/it-pro/windows-xp/bb490909(v=technet.10)?redirectedfrom=MSDN

要注意的一件事是,%~dp0修饰符仅在批处理文件中有效,而在您尝试直接在命令行上运行时则无效。

答案 2 :(得分:1)

如果这就是脚本中的全部内容,请不要将其作为脚本运行,请删除它,然后直接在中运行命令:

"%SystemRoot%\System32\WindowsPowerShell\v1.0\powershell.exe" -Command "Get-NetConnectionProfile"

可能缩短为:

PowerShell Get-NetConnectionProfile