В чем смысл & ldquo; ~ & rdquo; в пакетном скрипте Windows? [Дубликат]

Вы можете сделать что-то вроде этого:

mysql_connect('localhost','user',password);
mysql_query("CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';");
mysql_query("GRANT ALL ON db1.* TO 'username'@'localhost'");
mysql_query("CREATE DATABASE newdatabase");
mysql_close();

Вы можете посмотреть документацию MySQL на GRANT и CREATE USER

289
задан StackzOfZtuff 4 October 2016 в 16:11
поделиться

9 ответов

Магические переменные % n содержат аргументы, используемые для вызова файла: %0 - это путь к самому bat-файлу, %1 - первый аргумент после, %2 является вторым и т. д.

Поскольку аргументы часто являются файловыми путями, для извлечения частей пути есть дополнительный синтаксис. ~d - это диск, ~p - это путь (без диска), ~n - имя файла. Они могут быть объединены, поэтому ~dp - это диск + путь.

%~dp0 поэтому очень полезен в летучей мыши: это папка, в которой находится исполняемый файл bat.

Вы также можете получить другую информацию о файле: ~t - это метка времени, ~z - размер.

Посмотрите здесь для справки для всех команд командной строки. Коды тильды-магии описаны в для .

448
ответ дан JacquesB 15 August 2018 в 14:38
поделиться
  • 1
    note to self: echo %~dp0 не будет работать в командной строке только в пакетном файле. Duh! – northben 27 March 2015 в 19:40
  • 2
    есть ли разница между %~d0 и %~d0%? – Geoffrey 11 May 2015 в 13:23
  • 3
    @Pacerier:% 0 - полный путь, включая имя файла сценария. % ~ dp0 - это путь к папке, содержащей скрипт, но исключая имя файла сценария. – JacquesB 15 July 2015 в 19:06
  • 4
    note to self: echo %~pd0 дает тот же результат, что и echo %~dp0 (вместо обратного, как ожидалось). Кроме того, значение %0 равно в зависимости от того, дважды ли вы щелкните командный файл или запустите его из cmd. – Pacerier 11 August 2015 в 12:09

%~d0 дает вам букву диска аргумента 0 (имя скрипта), %~p0 путь.

6
ответ дан Armin Ronacher 15 August 2018 в 14:38
поделиться

Да, есть другие ярлыки, которые вы можете использовать, которые приведены ниже. В вашей команде ~ d0 будет означать букву диска 0-го аргумента.

~ expands the given variable
d gets the drive letter only
0 is the argument you are referencing

Поскольку 0-й аргумент представляет собой путь к скрипту, он получает букву диска пути для вас. Вы также можете использовать следующие ярлыки.

%~1         - expands %1 removing any surrounding quotes (")
%~f1        - expands %1 to a fully qualified path name
%~d1        - expands %1 to a drive letter only
%~p1        - expands %1 to a path only
%~n1        - expands %1 to a file name only
%~x1        - expands %1 to a file extension only
%~s1        - expanded path contains short names only
%~a1        - expands %1 to file attributes
%~t1        - expands %1 to date/time of file
%~z1        - expands %1 to size of file
%~$PATH:1   - searches the directories listed in the PATH
               environment variable and expands %1 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    

%~dp1       - expands %1 to a drive letter and path only
%~nx1       - expands %1 to a file name and extension only
%~dp$PATH:1 - searches the directories listed in the PATH
               environment variable for %1 and expands to the
               drive letter and path of the first one found.
%~ftza1     - expands %1 to a DIR like output line

Это также можно найти непосредственно в командной строке при запуске CALL /? или FOR /?

40
ответ дан Clewaks 15 August 2018 в 14:38
поделиться

Это расширенные подстановки переменных. Они изменяют переменные% N, используемые в пакетных файлах. Очень полезно, если вы участвуете в пакетном программировании в Windows.

%~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

Вы можете найти это, выполнив FOR /? .

129
ответ дан Cristian Ciupitu 15 August 2018 в 14:38
поделиться

Этот код объясняет использование символа ~ tilda, что было для меня самым запутанным. Как только я понял это, это значительно облегчает понимание:

@ECHO off
SET "PATH=%~dp0;%PATH%"
ECHO %PATH%
ECHO.
CALL :testargs "these are days" "when the brave endure"
GOTO :pauseit
:testargs
SET ARGS=%~1;%~2;%1;%2
ECHO %ARGS%
ECHO.
exit /B 0
:pauseit
pause
2
ответ дан djangofan 15 August 2018 в 14:38
поделиться

Еще один совет, который поможет многому - установить текущий каталог на другой диск, сначала нужно будет использовать %~d0, затем cd %~dp0. Это изменит каталог на диск пакетного файла, а затем переключится на его папку.

Для #oneLinerLovers, cd /d %~dp0 изменит как диск, так и каталог:)

Надеюсь, что это поможет кто-то.

7
ответ дан Marvin Thobejane 15 August 2018 в 14:38
поделиться
  • 1
    другой вариант - pushd %~dp0, который не имеет проблем с изменением текущего диска и дает дополнительный бонус для возможности popd вернуться к исходному диску / пути позже. – bcrist 13 March 2016 в 02:48

Некоторые исправления, на которые следует обратить внимание:

Если вы дважды щелкните командный файл %0, будет окружен кавычками. Например, если вы сохраните этот файл как c:\test.bat:

@echo %0
@pause

Двойной щелчок откроет новую командную строку с выходом:

"C:\test.bat"

Но если вы сначала откройте командную строку и вызовите ее непосредственно из этой командной строки, %0 будет ссылаться на все, что вы набрали. Если вы наберете test.bat Enter, вывод %0 не будет иметь кавычек, потому что вы не вводили кавычки:

c:\>test.bat
test.bat

Если вы наберете test Enter, вывод %0 будет иметь нет расширения, потому что вы не вводили расширение:

c:\>test
test

То же самое для tEsT Введите:

c:\>tEsT
tEsT

Если вы наберете "test" Enter, вывод %0 будут иметь кавычки (поскольку вы их набрали), но не расширение:

c:\>"test"
"test"

Наконец, если вы наберете "C:\test.bat", вывод будет таким, как если бы вы дважды нажали на него:

c:\>"C:\test.bat"
"C:\test.bat"

Обратите внимание, что это не все возможные значения %0 могут быть вызваны тем, что вы можете вызвать скрипт из других папок:

c:\some_folder>/../teST.bAt
/../teST.bAt

Все приведенные выше примеры также повлияют на %~0, потому что выход %~0 является просто выходом %0 минус-кавычек (если есть).

3
ответ дан Pacerier 15 August 2018 в 14:38
поделиться

Из Разбор имени файла в пакетном файле и другие идиомы - Real-How [to] :

Путь (без диска), где скрипт: ~ p0

Диск, где скрипт: ~ d0

9
ответ дан Wolf 15 August 2018 в 14:38
поделиться

Отображает текущее местоположение файла или каталога, в котором вы сейчас находитесь. если ваш пакетный файл был в каталоге рабочего стола, тогда «% ~ dp0» отобразит каталог рабочего стола. если вы хотите, чтобы он отображал текущий каталог с текущим именем файла, вы можете ввести «% ~ dp0% ~ n0% ~ x0».

0
ответ дан zask 15 August 2018 в 14:38
поделиться
Другие вопросы по тегам:

Похожие вопросы: