Кавычки, ограничивающие строки с обеих сторон, служат для предотвращения интерпретации специальных символов, которые могут находиться в строке. (Символ называется «специальным», если он несет дополнительную смысловую нагрузку, например символ шаблона — * .)
Некоторые программы и утилиты могут вызываться с дополнительными параметрами, содержащими специальными символы, поэтому очень важно предотвратить интерпретацию передаваемых параметров командной оболочкой, позволяя сделать это вызываемой программой.
Примечательно, что «не окавыченный» вариант команды grep [Пп]ервая *.txt будет правильно исполняться в Bash, но не в tcsh.
Вообще, желательно использовать двойные кавычки ( » » ) при обращении к переменным. Это предотвратит интерпретацию специальных символов, которые могут содержаться в именах переменных, за исключением $ , ` (обратная кавычка) и \ (escape — обратный слэш). [1] То, что символ $ попал в разряд исключений, позволяет выполнять обращение к переменным внутри строк, ограниченных двойными кавычками ( «$variable»), т.е. выполнять подстановку значений переменных (см. Пример 4-1, выше).
Двойные кавычки могут быть использованы для предотвращения разбиения строки на слова. [2] Заключение строки в кавычки приводит к тому, что она передается как один аргумент, даже если она содержит пробельные символы — разделители.
Заключение в кавычки аргументов команды echo необходимо только в том случае, когда разбиение на отдельные слова сопряжено с определенными трудностями.
Пример 5-1. Вывод «причудливых» переменных
Одиночные кавычки ( ‘ ‘ ) схожи по своему действию с двойными кавычками, только не допускают обращение к переменным, поскольку специальный символ «$» внутри одинарных кавычек воспринимается как обычный символ. Внутри одиночных кавычек, любой специальный символ, за исключением ‘ , интерпретируется как простой символ. Одиночные кавычки ( «строгие, или полные кавычки» ) следует рассматривать как более строгий вариант чем двойные кавычки ( «нестрогие, или неполные кавычки» ).
Поскольку внутри одиночных кавычек даже экранирующий ( \ ) символ воспринимается как обычный символ, попытка вывести одиночную кавычку внутри строки, ограниченной одинарными кавычками, не даст желаемого результата.
Экранирование — это способ заключения в кавычки одиночного символа. Экранирующий ( escape ) символ ( \ ) сообщает интерпретатору, что следующий за ним символ должен восприниматься как обычный символ.
С отдельными командами и утилитами, такими как echo и sed, экранирующий символ может применяться для получения обратного эффекта — когда обычные символы при экранировании приобретают специальное значение.
Специальное назначение некоторых экранированных символов
используемых совместно с echo и sed \n
Источник
Кавычки
Кавычки, обрамляющие строку, предотвращают интерпретацию специальных символов, которые могут находиться в строке. Символ называется «специальным», если он не только означает самого себя но и имеет дополнительное значение для программ, например символ шаблона — *. В этом примере, символ «*», интерпретируется как шаблон:
А тут просто как символ «звездочка», естественно команда ls, не находит такого файла:
Имейте в виду, многие программы в передаваемых им параметрах, используют специальные символы, в этом случае нужно заключать их в кавычки, что-бы системная оболочка их не трогала, оставляя для вызываемой программы. В примере ниже, производится поиск в файлах, начинающихся на символы B или b в текущем рабочем каталоге, строк, начинающихся с символов T или t. Команда grep, получает в качестве параметра шаблон, если не заключить его в кавычки, он будет интерпретирован оболочкой, до того как попадет к grep, и ничего найдено не будет:
При обращении к переменным, желательно использовать двойные кавычки. Это позволит не интерпретировать специальные символы, содержащиеся в именах переменных, за исключением символов $, ` ( обратная кавычка) и \ ( обратный слэш ). То что символ $ является исключением, позволяет производить подстановку переменных в строке , то есть сценарий:
Кроме вышесказанного, двойные кавычки используются для предотвращения разбиения строки на слова:
Результат обеих команд echo, будет одинаков, но только на первый взгляд:
Заключать в кавычки аргументы команды echo, нужно только если разбиение вывода на слова, вызывает какие-то трудности.
Пример вывода необычных переменных:
Одиночные кавычки (‘ ‘), по своему действию схожи с двойными кавычками, но не разрешают внутри себя подстановку переменных, интерпретируя символ «$», как обычный символ. Любой символ внутри одинарных кавычек, за исключением символа одинарной кавычки, воспринимается как обычный символ. Одинарные кавычки являются более строгим вариантом двойных кавычек.
Поскольку внутри одиночных кавычек даже экранирующий (\) символ воспринимается как обычный символ, попытка вывести одиночную кавычку внутри строки, ограниченной одинарными кавычками, не даст желаемого результата, хотя при желании это можно обойти.
Вторая строка разбита на 3 подстроки, ограниченных одинарными кавычками, а между подстроками стоят экранированные одинарные кавычки, в первом случае кавычка экранируется с помощью обратного слэша, во втором, с помощью двойных кавычек.
При использовании с некоторыми командами, например echo и sed, экранирующий символ может применяться для получения инверсного результата, когда обычные символы при экранировании приобретают специальное значение.
Специальное назначение экранированных символов в echo и sed
Поведение символа «\» ( обратный слэш ), зависит от разных факторов, таких как: экранирован-ли он, заключен-ли в кавычки, используется в подстановке команд или в конструкции «вложенный документ».
Отдельные символы в строке, которая записывается в переменную, могут быть экранированы, исключение составляет сам экранирующий символ.
Данный сценарий вернет сообщение об ошибке:
Фактически, в данном примере, экранируется символ перевода строки, в итоге команда получается такой var=echo «$var».
Экранирование пробелов в командной строке объединяет все аргументы в один, например команда:
вернет листинг каталогов /etc и /root, а вариант
вернет «No such file or directory», поскольку фактически мы сказали команде ls вывести листинг каталога /etc/root, которого не существует.
Очень часто символ экранирования \ ( обратный слэш ), используется для ввода из командной строки многострочных команд, экранируя символ новой строки:
Приведенная команда копирует содержимое одной директории в другую, записана в 2 строки. Другой вариант той-же операции:
Вообще если одна из строк многострочной команды заканчивается символом конвейера » | «, экранировать символ новой строки не обязательно, это просто считается хорошим тоном, и применимо только к оболочке bash, например в csh это не работает.
Источник
Echo и экранирование спец-символов
Что-то никак не найду как экранировать >> ‘
Спасибо, ну и жесть.
Это не жесть, просто хитрый ход. В ‘-строке экранирования в принципе нет, поэтому ты завершаешь строку (первая ‘), потом вне строки экранируешь \’, потом заново открываешь. Засчет того, что между тремя токенами (. ‘, \’, ‘. ) нет пробелов, шел сливает это все в одну строку. Собственно все.
upd: гребаные пони
Вот тут как никогда кстати статическая типизация. Пример с кавычкой мой любимый
Ты хотел сказать «строгая типизация»?
Заносишь апостроф в переменную и вперед!
А какая разница? Если компилятор/интерпретатор динамически сортирует твои данные по типам — это явно не строгая типизация.
В пхп вроде можно 1+«2», а в питоне — нет.
Я, давным давно, когда надо было передавать пару байтов при минимуме потерь на код, использовал echo. Потом понял, что кавычки надо передавать вместе с костылями, так как в них заворачиваешь свои данные при вызове переменных, что заставляет извращаться с экранированием. Потому я поменял инструмент на printf(«%STRONG_TYPE_OF_DATA\n», dazhe_kavychka_data); и забыл про использование скриптовых языков при обработке тонкой материи
Но в целом идея тсу думаю понятна.
Кстати, если у нас двойные кавычки, то сабжевая проблема исчезает, а если одинарные, то исчезает интерполяция 🙂
Я на питоне ровно один раз писал. До того момента, пока он мне не стал указывать куда можно кавычку всунуть, а куда — стилистическая ошибка. Так что спорить не буду, использую perl и си как пример. В одном строго int для int, в другом — $i=Чего_Душе_Угодно, если лень
не работает ни в баше, ни в ksh. кстати, ему надо было вставить одинарную кавычку в поток _экранированный одинарными кавычками_, так что метод с переменной в любом случае не катит
то есть, познания в программировании у тебя весьма ограниченны, но при этом, цитируя классика, ты даешь советы космического масштаба и космичекой же глупости, при этом попытно путая термины. строгая и статическая типизация — независимые явления. http://ru.wikipedia.org/wiki/Типизация_данных#.D0.9A.D0.BE.D0.BD.D1.82.D1.80. .
ему надо было вставить одинарную кавычку в поток _экранированный одинарными кавычками_
По мне так строка с $q читабельнее, глаза не спотыкаются на схожих символах ‘\»
согласен, так лучше. сам так делаю =)
Да, я ужасно люблю умничать
ого, да ты никак адекватный! ничего, все мы этим страдаем, главное вовремя останавливаться и признавать свои ошибки.
Источник
Кавычки в bash
Оболочка распознает четыре типа знаков кавычек:
знак одиночной кавычки
знак двойной кавычки
знак обратного слэша
знак обратной кавычки
Одиночные кавычки
Чаще всего используются для объединения в единый элемент последовательности символов, включая пробелы. Рассмотрим пример:
Чтобы вывести сведения о конкретном абоненте, достаточно выполнить команду:
Было найдено два абонента. Попробуем уточнить поиск:
Это не работает. Проблема в том, что в оболочке пробелы служат для разделения аргументов команды. Команда grep интерпретирует первый аргумент как шаблон для поиска, а все остальные — как имена файлов для поиска. Теперь попробуем так:
Когда оболочка обнаруживает первую открывающую одинарную кавычку, она игнорирует любые последующие специальные символы до тех пор, пока не обнаружит вторую закрывающую кавычку. Важно подчеркнуть, что игнорируются все специальные символы, если они заключены в одиночные кавычки:
Кавычки требуются и в том случае, если переменным присваиваются значения, содержащие пробелы или специальные символы, хотя здесь имеются свои особенности:
Во втором случае показано, что при подстановке значения пременной text оболочка интерпретирует * как указание на подстановку имен файлов из текущей директории. Чтобы избежать этого, надо делать так:
Двойные кавычки
Двойные кавычки действуют таким же образом, как и одиночные, за исключением того, что они в меньшей стапени защищают свое содержимое. Если одиночные кавычки предписывают оболочке игнорировать все заключенные в них специальные символы, то двойные кавычки — игнорировать бо́льшую их часть. В частности, следующие три символа не игнорируются в двойных кавычках:
знак $
знак обратной кавычки
знак обратного слэша
Тот факт, что знак $ не игнорируется в двойных кавычках, означает, что вместо имени переменной оболочка подставляет значение этой переменной:
В последнем случае двойные кавычки предписывают оболочке подставить вместо имени переменной ее значение (символ * ). Но поскольку подстановка имен файлов не выполняется в двойных кавычках, то символ * передается команде echo как отображаемое значение.
Рассмотрим еще один пример, нагладно демонстрирующий, чем отстутствие кавычек отличается от наличия двойных кавычек:
Оболочка ужаляет символы прообела, табуляции и новой строки (т.е. все пробельные символы) из командной строки, а затем разделяет ее на аргументы, прежде чем передать их запрашиваемой команде. Поэтому при выводе значения переменной $address без кавычек, оболочка удалила символ новой строки. А затем передала команде echo девять аргументов.
Во втором случае, когда выводится значение переменной $address в кавычках, оболочка оставляет без внимания любые заключенные в них пробелы. Таким образом, оболочка передаст команде echo единственный аргумент, содержащий символ новой строки.
Обратный слэш
Функционально обратный слэш перед символом равнозначен заключению этого символа в одиночные кавычки, хотя и за рядом незначительных исключений. Обратный слэш экранирует следующий сразу за ним символ:
Когда обратный слэш указывается последним во вводимой строке, оболочка интерпретирует его как знак продолжения строки. В этом случае она удаляет следующий далее знак новой строки, не интерпретируя его как разделитель аргументов, как будто его вообще не было:
Как уже упоминалось, обратный слэш относится к числу трех символов, интерпретируемых оболочкой в двойных кавычках. Это означает, что с помощью обратного слэша можно экранировать символы $ и двойных кавычек:
Подстановка команд
Оболочка имеет возможность заменить указанную команду результатом ее выполнения в любом месте командной строки. Выполнить подстановку можно двумя способами: заключив команду в обратные кавычки или использовать конструкцию $(…) .