powershell - извлечь имя файла и расширение - PullRequest
96 голосов
/ 20 марта 2012

Мне нужно извлечь имя файла и расширение, например, из my.file.xlsx. Я не знаю имени файла или расширения, и в имени может быть больше точек, поэтому мне нужно найти строку справа, а когда я найду первую точку (или последнюю слева), извлеките часть на правая сторона и часть слева от этой точки.

Может быть, есть лучшее решение, но я не нашел ничего здесь или где-либо еще. Спасибо

Ответы [ 8 ]

148 голосов
/ 20 марта 2012

Если файл идет с диска и, как говорили другие, используйте свойства BaseName и Extension:

PS C:\> dir *.xlsx | select BaseName,Extension

BaseName                                Extension
--------                                ---------
StackOverflow.com Test Config           .xlsx  

Если вам дано имя файла как часть строки (скажем,из текстового файла), я бы использовал статические методы GetFileNameWithoutExtension и GetExtension из класса System.IO.Path :

PS C:\> [System.IO.Path]::GetFileNameWithoutExtension("Test Config.xlsx")
Test Config
PS H:\> [System.IO.Path]::GetExtension("Test Config.xlsx")
.xlsx
21 голосов
/ 16 апреля 2015
PS C:\Windows\System32\WindowsPowerShell\v1.0>split-path "H:\Documents\devops\tp-mkt-SPD-38.4.10.msi" -leaf
tp-mkt-SPD-38.4.10.msi

PS C:\Windows\System32\WindowsPowerShell\v1.0> $psversiontable

Name                           Value
----                           -----
CLRVersion                     2.0.50727.5477
BuildVersion                   6.1.7601.17514
PSVersion                      2.0
WSManStackVersion              2.0
PSCompatibleVersions           {1.0, 2.0}
SerializationVersion           1.1.0.1
PSRemotingProtocolVersion      2.1
11 голосов
/ 20 марта 2012

Если это из текстового файла и предполагаемый файл имени окружен пробелами, это способ:

$a = get-content c:\myfile.txt

$b = $a | select-string -pattern "\s.+\..{3,4}\s" | select -ExpandProperty matches | select -ExpandProperty value

$b | % {"File name:{0} - Extension:{1}" -f $_.substring(0, $_.lastindexof('.')) , $_.substring($_.lastindexof('.'), ($_.length - $_.lastindexof('.'))) }

Если это файл, вы можете использовать что-то подобное, исходя из своих потребностей:

$a = dir .\my.file.xlsx # or $a = get-item c:\my.file.xlsx 

$a
    Directory: Microsoft.PowerShell.Core\FileSystem::C:\ps


Mode           LastWriteTime       Length Name
----           -------------       ------ ----
-a---      25/01/10    11.51          624 my.file.xlsx


$a.BaseName
my.file
$a.Extension
.xlsx
8 голосов
/ 25 декабря 2015
PS C:\Users\joshua> $file = New-Object System.IO.FileInfo('file.type')
PS C:\Users\joshua> $file.BaseName, $file.Extension
file
.type
8 голосов
/ 20 марта 2012

Проверьте свойства BaseName и Extension объекта FileInfo.

5 голосов
/ 28 сентября 2016

Использовать Split-Path

$filePath = "C:\PS\Test.Documents\myTestFile.txt";
$fileName = (Split-Path -Path $filePath -Leaf).Split(".")[0];
$extension = (Split-Path -Path $filePath -Leaf).Split(".")[1];
3 голосов
/ 29 января 2017

просто сделай это:

$file=Get-Item "C:\temp\file.htm"
$file.Name
$file.Extension
0 голосов
/ 04 марта 2015

Это адаптация, если кому-то интересно. Мне нужно было проверить, успешно ли RoboCopy скопировал один файл на несколько серверов для его целостности:

   $Comp = get-content c:\myfile.txt

ForEach ($PC in $Comp) {
    dir "\\$PC\Folder\Share\*.*" | Select-Object $_.BaseName
}

Красиво и просто, и показывает каталог и файл внутри него. Если вы хотите указать одно имя файла или расширение, просто замените * на все, что вы хотите.

    Directory: \\SERVER\Folder\Share

Mode                LastWriteTime     Length Name                                                                                                                                             
----                -------------     ------ ----                                                                                                                                             
-a---         2/27/2015   5:33 PM    1458935 Test.pptx                                                                                                             
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...