Pourquoi ça ?
On pourrait trouver une réponse à " Pourquoi ça ? " dans Wildcards article :
The * wildcard will match any sequence of characters
(0 or more, including NULL characters)
The ? wildcard will match a single character
(or a NULL at the end of a filename)
Règles de correspondance par caractères génériques
-
*
Correspond généralement à 0 ou plusieurs caractères, à une exception près (voir la règle suivante). Le caractère générique non avide est libre de correspondre à autant de caractères ou plus que nécessaire. caractères que nécessaire pour que le reste du masque corresponde. corresponde.
-
*.
À la fin du masque, la règle correspond à 0 caractère ou plus, à l'exception de {dot}. En réalité, la règle s'applique avec n'importe quel nombre de caractères {dot} et {espace} entre le * et le {point} terminal. L'expression régulière régulière pour ce terme est "[*][. ]*[.]$"
-
?
Correspond à 0 ou un caractère, sauf {dot}. La seule fois où elle correspond à 0 caractère est lorsqu'elle correspond à la fin du nom, ou à la position avant un {point}. Le point d'interrogation peut également être utilisé plusieurs fois une fois pour faire correspondre plus d'un caractère.
Implication . En dernier {dot} dans un nom de fichier/dossier sépare le nom de la base et l'extension. Ainsi,
-
dir *.
affiche tous les articles avec aucune extension et
-
dir *.*
affiche tous les articles avec extension de zéro ou plusieurs caractères .
A proprement parler, dir *.
affiche tous les articles avec pas de période ( .
) en nom . (BTW, Nommer les fichiers, les chemins et les espaces de noms L'article de MSDN dit explicitement que " il est acceptable de spécifier un point comme premier caractère d'un nom ".)
Existe-t-il un moyen de ne lister que les fichiers avec un point ?
Je ne pense pas. Cependant, il existe une solution de contournement avec une expression régulière adaptée.
PowerShell (solution complète si elle est utilisée dans une console Powershell) :
:: PowerShell - no extension, full syntax
PowerShell -c "Get-ChildItem | Where-Object {$_.Name -match '^.[^\.]*$'}"
:: PowerShell - extension, alias syntax
PowerShell -c "dir | ? {$_.Name -match '^..*\...*$'}"
Cmd (une idée seulement, qui pourrait nécessiter une certaine élaboration) :
:: CMD/batch - no extension
for /F "delims=" %%G in ('dir /OGN /B ^| findstr "^.[^\.]*$"') do @echo %%~tG %%~aG %%~zG %%~nxG
:: CMD/batch - extension
for /F "delims=" %%G in ('dir /OGN /B ^| findstr "^..*\...*$"') do @echo %%~tG %%~aG %%~zG %%~nxG
Addendum : un bonus et une explication
Une supposition intuitive que Name
est concaténée BaseName
y Extension
ne tient pas . Le script suivant le prouve à l'aide de cmd
y PowerShell
les caractéristiques de base, et le bizarre ^..*\...*$
regex est dérivé de ses résultats.
@ECHO OFF
SETLOCAL EnableExtensions DisableDelayedExpansion
set "_workingDirectory=%~1"
if "%_workingDirectory%"=="%tmp%\tests_SU_1193102" (
>NUL 2>&1 (
mkdir "%_workingDirectory%"
pushd "%_workingDirectory%"
rem make directories
mkdir .Fldr-Ext
mkdir aFldr-Ext
mkdir .Fldr.Ext
mkdir aFldr.Ext
rem create files
copy NUL .File-Ext
copy NUL aFile-Ext
copy NUL .File.Ext
copy NUL aFile.Ext
popd
)
) else if "%_workingDirectory%"=="" set "_workingDirectory=%CD%"
pushd "%_workingDirectory%"
set "_first=ItemName Attributes BaseName Extension"
echo ON
:: dir /OGN | findstr "Ext$"
for /F "delims=" %%G in ('dir /OGN /B') do @((if defined _first (echo %_first%&echo(&set "_first="))&echo %%~nxG %%~aG %%~nG %%~xG)
:: Get-ChildItem | Select-Object -Property Mode, BaseName, Extension, Name
PowerShell -c "dir | select -pr Name, Mode, BaseName, Extension | sort -pr @{Expression='Mode';Descending=$true}, @{Expression='Name';Descending=$false}"
Sortie :
==> D:\bat\BaseName_vs_Extension.bat "%tmp%\tests_SU_1193102"
==> for /F "delims=" %G in ('dir /OGN /B') do @((if defined _first (echo ItemName Attributes BaseName Extension & echo( & set "_first=" ) ) & echo %~nxG %~aG %~nG %~xG )
ItemName Attributes BaseName Extension
.Fldr.Ext d---------- .Fldr .Ext
.Fldr-Ext d---------- .Fldr-Ext
aFldr.Ext d---------- aFldr .Ext
aFldr-Ext d---------- aFldr-Ext
.File.Ext --a-------- .File .Ext
.File-Ext --a-------- .File-Ext
aFile.Ext --a-------- aFile .Ext
aFile-Ext --a-------- aFile-Ext
==> PowerShell -c "dir | select -pr Name, Mode, BaseName, Extension | sort -pr @{Expression='Mode';Descending=$true}, @{Expression='Name';Descending=$false}"
Name Mode BaseName Extension
---- ---- -------- ---------
.Fldr.Ext d----- .Fldr.Ext .Ext
.Fldr-Ext d----- .Fldr-Ext .Fldr-Ext
aFldr.Ext d----- aFldr.Ext .Ext
aFldr-Ext d----- aFldr-Ext
.File.Ext -a---- .File .Ext
.File-Ext -a---- .File-Ext
aFile.Ext -a---- aFile .Ext
aFile-Ext -a---- aFile-Ext
Comparez la définition de BaseName
différente pour les fichiers et les dossiers :
PS D:\PShell> Get-ChildItem | Get-Member -Name BaseName | Format-List -property TypeName, Definition
TypeName : System.IO.DirectoryInfo
Definition : System.Object BaseName {get=$this.Name;}
TypeName : System.IO.FileInfo
Definition : System.Object BaseName {get=if ($this.Extension.Length -gt
0){$this.Name.Remove($this.Name.Length -
$this.Extension.Length)}else{$this.Name};}
Mi première réponse était basé sur un malentendu impardonnable :
Lire dir /?
utiliser dir /A:-D
:
~~> /A Displays files with specified attributes.
attributes D Directories R Read-only files
H Hidden files A Files ready for archiving
S System files I Not content indexed files
L Reparse Points - Prefix meaning not
~~
Autre approche : appliquer findstr
regex かわりに dir *.* | findstr /V "<.*>"