I have a script that duplicates a Word doc template and renames each using a csv file with a list of names. What would be the equivalent code if instead of a csv file I use a text file?

Import-csv ‘.\individuals2.csv’ | foreach-object {
	$newname = ‘2 ‘ + $_.name + '.docx’
	Copy-item '.\template.docx' $newname
}
  • mikyopii@programming.dev
    link
    fedilink
    arrow-up
    0
    ·
    edit-2
    8 months ago

    His example doesn’t seem to perform any comparisons to determine what to name the file. If the text file is just a list then something like this could work:

    $file = Get-Content -Path .\individuals2.txt

    foreach ($line in $file) { Copy-Item -Path .\template.docx -Destination “.$(2 + $line + ‘.docs’)” }

    Edit: Wow, Lemmy destroys formatting.

    • brisk@aussie.zone
      link
      fedilink
      arrow-up
      0
      ·
      8 months ago

      It’s markdown, you should be able to indent your lines by 4 spaces or fence with triple backtics to get code blocks. Your client’s editor may have a button to help

      ```
      $file = Get-Content -Path .\individuals2.txt
      
      foreach ($line in $file)
      {
          Copy-Item -Path .\template.docx -Destination ".\$(2 + $line + '.docs')"
      }
      ```
      

      Becomes

      $file = Get-Content -Path .\individuals2.txt
      
      foreach ($line in $file)
      {
          Copy-Item -Path .\template.docx -Destination ".\$(2 + $line + '.docs')"
      }