Eh bien, pour obtenir simplement le nom de fichier de votre lot, le moyen le plus simple serait d'utiliser %~n0
.
@echo %~n0
affichera le nom (sans l'extension) du fichier de commandes en cours d'exécution (sauf s'il est exécuté dans un sous-programme appelé par call
). La liste complète de ces substitutions «spéciales» pour les noms de chemin peut être trouvée avec help for
, à la toute fin de l'aide:
De plus, la substitution des références de variable FOR a été améliorée. Vous pouvez maintenant utiliser la syntaxe facultative suivante:
%~I - expands %I removing any surrounding quotes (")
%~fI - expands %I to a fully qualified path name
%~dI - expands %I to a drive letter only
%~pI - expands %I to a path only
%~nI - expands %I to a file name only
%~xI - expands %I to a file extension only
%~sI - expanded path contains short names only
%~aI - expands %I to file attributes of file
%~tI - expands %I to date/time of file
%~zI - expands %I to size of file
%~$PATH:I - searches the directories listed in the PATH
environment variable and expands %I to the
fully qualified name of the first one found.
If the environment variable name is not
defined or the file is not found by the
search, then this modifier expands to the
empty string
Les modificateurs peuvent être combinés pour obtenir des résultats composés:
%~dpI - expands %I to a drive letter and path only
%~nxI - expands %I to a file name and extension only
%~fsI - expands %I to a full path name with short names only
Pour répondre précisément à votre question, cependant: les sous-chaînes sont effectuées en utilisant la :~start,length
notation:
%var:~10,5%
va extraire 5 caractères de la position 10 dans la variable d'environnement %var%
.
REMARQUE: L'index des chaînes est basé sur zéro, donc le premier caractère est à la position 0, le second à 1, etc.
Pour obtenir des variables sous - chaînes d'arguments tels que %0
, %1
, etc. , vous devez les assigner à une variable d'environnement normal en utilisant d' set
abord:
:: Does not work:
@echo %1:~10,5
:: Assign argument to local variable first:
set var=%1
@echo %var:~10,5%
La syntaxe est encore plus puissante:
%var:~-7%
extrait les 7 derniers caractères de %var%
%var:~0,-4%
extrait tous les caractères sauf les quatre derniers qui vous débarrasseraient également de l'extension de fichier (en supposant trois caractères après le point [ .
]).
Voir help set
pour plus de détails sur cette syntaxe.
setlocal ENABLEDELAYEDEXPANSION \r\n for /f %%s in ('set') do ( \r\n set tmp=%%s \r\n echo !tmp:~-3! \r\n )
FOR
boucles?FOR
est une construction fondamentale dans les fichiers batch effectuant un très grand nombre de tâches diverses. Btw, il existe un autre moyen de faire face à la tâche en utilisant un sous-programme, c'estfor /f %%s in ('set') do call :DoSmth "%%s" \r\n ... \r\n :DoSmth \r\n set var=%1 \r\n echo %var:~1,3%
%date:~0,2%%date:~3,2%%date:~6,4%%time:~0,2%%time:~3,2%%time:~6,2%
%date%
pour construire une date dans un certain format. Le format est spécifique à la culture de l'utilisateur et peut changer. Utilisez plutôt WMI pour obtenir la date et l'heure dans un format utile qui ne dépend pas des paramètres de l'utilisateur. Je ne sais pas non plus ce que fait ce commentaire ici, car cette question ne portait pas sur la date ou l'heure.Bien expliqué ci-dessus!
Pour tous ceux qui peuvent souffrir comme moi pour que cela fonctionne dans un Windows localisé (le mien est XP en slovaque), vous pouvez essayer de remplacer le
%
par un!
Alors:
la source
setlocal ENABLEDELAYEDEXPANSION
commandeComme information supplémentaire à la réponse de Joey, qui n'est pas décrite dans l'aide de
set /?
nifor /?
.%~0
se développe au nom du propre lot, exactement comme il a été tapé.Donc, si vous démarrez votre lot, il sera développé comme
Mais il y a une exception, l'expansion dans un sous-programme peut échouer
Cela se traduit par
Dans une fonction se
%~0
développe toujours au nom de la fonction, pas du fichier de commandes.Mais si vous utilisez au moins un modificateur, il affichera à nouveau le nom du fichier!
la source