Toon posts:

Powershell append

Pagina: 1
Acties:

Vraag


  • Michel
  • Registratie: November 2012
  • Laatst online: 03-02 11:34
Goedemiddag!

Laten we even beginnen met het melden dat mijn powershell kennis vrij beperkt is op het moment.

Veelvuldig moet ik hardwarehashes van batches laptops ophalen voor Autopilot. Hiervoor maak ik gebruik van het autopilot powershell script van de powershell galaries van Microsoft (https://www.powershellgallery.com/packages/Get-WindowsAutoPilotInfo/1.3/Content/Get-WindowsAutoPilotInfo.ps1)

Om te zorgen dat deze makkelijk is uit te voeren op nieuwe laptops (zonder deze te configureren), en om te zorgen dat iedereen er mee over weg kan bij ons heb ik een klein bat script uitgewerkt welke zorgt dat Powershell scripts uitgevoerd mogen worden, het powershell script uitvoert en de output in een CSV zet, en vervolgens de executionpolicy weer aanpast naar default (restricted)
@ECHO off

ECHO Toestaan dat Powershell scripts mag uitvoeren
powershell -Command "& {Set-ExecutionPolicy unrestricted;}"
ECHO Powershell script voor hardwarehash uitvoeren...
powershell -Command "\Get-WindowsAutoPilotInfo.ps1 -ComputerName $env:computername -OutputFile D:\AutopilotImport.csv"
ECHO Toestaan dat powershell scripts mag uitvoeren terug draaien
powershell -Command "& {Set-ExecutionPolicy restricted;}"
ECHO Afgerond en gegevens geëxporteerd naar D:\AutopilotImport.csv
PAUSE
Nu mijn vragen!
1) Als ik de USB met het script in de laptop steek krijgt deze altijd de D schijf, wegschrijven is dus op die manier geen probleem. Maar als men vergeet eerst de Windows stick te verwijderen krijgt de script USB een andere letter en werkt het wegschrijven niet. Hoe kan ik zorgen dat het csv bestand wordt weggeschreven naar de stick waar vandaan het script wordt uitgevoerd?

2) Hoe kan ik zorgen dat hij het csv bestand aanvult in plaats van overschrijft?

Ik heb al gezocht naar manieren met -append en dergelijke maar dat werkt niet in een bat script. Ook met de bekende >> kom ik niet verder. Helaas kom ik via google niet bij de juiste sites terecht die een dergelijke constructie gebruiken.

Het gedeelte van het wegschrijven naar CSV heb ik gejat uit het get-autopilot powershell script, hierin staan allerlei voorbeelden voor commando's.

Alvast bedankt!!

Michel

[Voor 3% gewijzigd door Michel op 16-10-2018 16:37]

Alle reacties


  • downtime
  • Registratie: Januari 2000
  • Niet online

downtime

Everybody lies

miesjel12 schreef op dinsdag 16 oktober 2018 @ 16:35:

1) Als ik de USB met het script in de laptop steek krijgt deze altijd de D schijf, wegschrijven is dus op die manier geen probleem. Maar als men vergeet eerst de Windows stick te verwijderen krijgt de script USB een andere letter en werkt het wegschrijven niet. Hoe kan ik zorgen dat het csv bestand wordt weggeschreven naar de stick waar vandaan het script wordt uitgevoerd?
Join-Path -Path (Split-Path -Parent $MyInvocation.MyCommand.Path) -ChildPath ‘AutopilotImport.csv’

  • opblaashaas
  • Registratie: Juli 2009
  • Laatst online: 01-02 16:34

opblaashaas

Blijehippie met metalen hoofd.

of gewoon export-csv -file "$psscriptroot`\durr.csv" -append -notypeinformation als je powershell 3 of nieuwer hebt

[Voor 25% gewijzigd door opblaashaas op 16-10-2018 23:09]

eve gate


  • Michel
  • Registratie: November 2012
  • Laatst online: 03-02 11:34
opblaashaas schreef op dinsdag 16 oktober 2018 @ 23:08:
of gewoon export-csv -file "$psscriptroot`\durr.csv" -append -notypeinformation als je powershell 3 of nieuwer hebt
Dit is dan ter vervanging van die -outputfile? Begrijp ik dat goed?


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee