Skip to content

New-CustomFileName

SYNOPSIS

Create a custom file name based on a template.

SYNTAX

New-CustomFileName [-Template] <String> [-Case <String>] [<CommonParameters>]

DESCRIPTION

This command will generate a custom file name based on a template string that you provide. You can create a template string using any of these variables. Most of these should be self-explanatory

  • %username
  • %computername
  • %year - 4 digit year
  • %yr - 2 digit year
  • %monthname - The abbreviated month name
  • %month - The month number
  • %dayofweek - The full name of the week day
  • %day
  • %hour - the hour of the day in 12-hour format to 2 digits
  • %hour24 - the hour of the day in 24-hour format to 2 digits
  • %minute
  • %seconds
  • %time - A compact string of HourMinuteSecond
  • %string - A random string
  • %guid

You can also insert a random number using %### with a # character for each digit. If you want a 2 digit random number use %##. If you want 6 digits, use %######.

The command will attempt to preserve case for any non-pattern string, but you should separate it from other placeholder patterns with one of these characters: - ( ) [ ] or a . Using an underscore will not work.

Another option, is to turn the entire custom name into upper or lower case.

EXAMPLES

EXAMPLE 1

PS C:\> New-CustomFileName %computername_%day%monthname%yr-%time.log
COWPC_28Nov20-142138.log

EXAMPLE 2

PS C:\> New-CustomFileName %dayofweek-%####.dat
Tuesday-3128.dat

Create a custom file name using the day of the week and a 4 digit random number.

EXAMPLE 3

PS C:\> New-CustomFileName %username-%string.tmp -Case Upper
JEFF-Z0XUXMFS.TMP

Create an upper case custom file name. The %string placeholder will be replaced with a random 8 character string.

EXAMPLE 4

PS C:\> Join-Path c:\work (New-CustomFilename "%Year%Monthname-LOG-%computername[%username].txt" -case lower)
c:\work\2020nov-log-bovine320[jeff].txt

Create a lower case filename using Join-Path. This command does not create the file, it only generates a name for you to use.

EXAMPLE 5

PS C:\> 1..10 | foreach-object {
    $file = New-Item (Join-Path c:\work\data (New-CustomFileName %string-%####.dat))
    $stream =$file.open("OpenOrCreate")
    $stream.Seek((Get-Random -minimum 250 -Maximum 2KB), "Begin") | Out-Null
    $stream.WriteByte(0)
    $stream.Close()
    $file
}

    Directory: C:\work\data

Mode                LastWriteTime         Length Name
----                -------------         ------ ----
-a----        3/15/2020   4:46 PM            976 rcphz2nj-6431.dat
-a----        3/15/2020   4:46 PM           1797 viz32er5-0526.dat
-a----        3/15/2020   4:46 PM           1775 k2mukuv4-8267.dat
-a----        3/15/2020   4:46 PM            666 0encqdlt-8753.dat
-a----        3/15/2020   4:46 PM            513 dbswpujf-6314.dat
-a----        3/15/2020   4:46 PM            371 qlkdufp0-0481.dat
-a----        3/15/2020   4:46 PM           2010 5cxq3tb5-5624.dat
-a----        3/15/2020   4:46 PM           2043 mcvoh4n5-8041.dat
-a----        3/15/2020   4:46 PM           1048 4iwibnmf-1584.dat
-a----        3/15/2020   4:46 PM            378 fgsj0rtd-2894.dat

Create 10 dummy files with random names and sizes.

PARAMETERS

-Case

Some values like username or computername might be in a different case than what you want. You can use the default value, or return a value that is all upper or lower case.

Type: System.String
Parameter Sets: (All)
Aliases:
Accepted values: Lower, Upper, Default

Required: False
Position: Named
Default value: None
Accept pipeline input: False
Accept wildcard characters: False

-Template

A string that defines the naming pattern based on a set of placeholders. You can create a template string using any of these variables, including the % symbol.

  • %username
  • %computername
  • %year - 4 digit year
  • %yr - 2 digit year
  • %monthname - The abbreviated month name
  • %month - The month number
  • %dayofweek - The full name of the week day
  • %day
  • %hour - the hour of the day in 12-hour format to 2 digits
  • %hour24 - the hour of the day in 24-hour format to 2 digits
  • %minute
  • %seconds
  • %time - A compact string of HourMinuteSecond
  • %string - A random string
  • %guid
  • %### - a random number matching the number of # characters
Type: System.String
Parameter Sets: (All)
Aliases:

Required: True
Position: 0
Default value: None
Accept pipeline input: False
Accept wildcard characters: False

CommonParameters

This cmdlet supports the common parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutVariable, -OutBuffer, -PipelineVariable, -Verbose, -WarningAction, and -WarningVariable. For more information, see about_CommonParameters.

INPUTS

None

OUTPUTS

System.String

NOTES

Learn more about PowerShell: http://jdhitsolutions.com/blog/essential-powershell-resources/

New-RandomFileName

Back to top