Ваша проблема в том, что переменная get заменяется, когда пакетный процессор считывает команду for перед ее исполнением.
Попробуйте следующее:
SET temp=Hello, world!
CALL yourbatchfile.bat
И вы увидите Hello напечатано 5 раз.
Решение задерживается расширением; вам нужно сначала включить его, а затем использовать !temp!
вместо %temp%
:
@echo off
SETLOCAL ENABLEDELAYEDEXPANSION
FOR /R %%X IN (*.txt) DO (
set temp=%%~nX
echo directory !temp:~0,7!
)
Подробнее см. здесь .
Я закончил тем, что писал сценарий (я пытаюсь преподавать мне тонкости сценариев удара, так вот почему Вы не видите что-то как Perl здесь). Это не точно простое дело, но это делает большую часть того, в чем я нуждаюсь. Это использует предложение Kyle для поиска crontabs отдельных пользователей, но также и имеет дело с /etc/crontab
(включая сценарии, запущенные run-parts
в /etc/cron.hourly
, /etc/cron.daily
, и т.д.) и задания в /etc/cron.d
каталог. Это берет всех тех и объединяет их в дисплей что-то как следующее:
mi h d m w user command
09,39 * * * * root [ -d /var/lib/php5 ] && find /var/lib/php5/ -type f -cmin +$(/usr/lib/php5/maxlifetime) -print0 | xargs -r -0 rm
47 */8 * * * root rsync -axE --delete --ignore-errors / /mirror/ >/dev/null
17 1 * * * root /etc/cron.daily/apt
17 1 * * * root /etc/cron.daily/aptitude
17 1 * * * root /etc/cron.daily/find
17 1 * * * root /etc/cron.daily/logrotate
17 1 * * * root /etc/cron.daily/man-db
17 1 * * * root /etc/cron.daily/ntp
17 1 * * * root /etc/cron.daily/standard
17 1 * * * root /etc/cron.daily/sysklogd
27 2 * * 7 root /etc/cron.weekly/man-db
27 2 * * 7 root /etc/cron.weekly/sysklogd
13 3 * * * archiver /usr/local/bin/offsite-backup 2>&1
32 3 1 * * root /etc/cron.monthly/standard
36 4 * * * yukon /home/yukon/bin/do-daily-stuff
5 5 * * * archiver /usr/local/bin/update-logs >/dev/null
Примечание, которое это показывает пользователю, и более или менее видам к часу и минуте так, чтобы я видел ежедневное расписание.
До сих пор, я протестировал его на Ubuntu, Debian и AS Red Hat.
#!/bin/bash
# System-wide crontab file and cron job directory. Change these for your system.
CRONTAB='/etc/crontab'
CRONDIR='/etc/cron.d'
# Single tab character. Annoyingly necessary.
tab=$(echo -en "\t")
# Given a stream of crontab lines, exclude non-cron job lines, replace
# whitespace characters with a single space, and remove any spaces from the
# beginning of each line.
function clean_cron_lines() {
while read line ; do
echo "${line}" |
egrep --invert-match '^($|\s*#|\s*[[:alnum:]_]+=)' |
sed --regexp-extended "s/\s+/ /g" |
sed --regexp-extended "s/^ //"
done;
}
# Given a stream of cleaned crontab lines, echo any that don't include the
# run-parts command, and for those that do, show each job file in the run-parts
# directory as if it were scheduled explicitly.
function lookup_run_parts() {
while read line ; do
match=$(echo "${line}" | egrep -o 'run-parts (-{1,2}\S+ )*\S+')
if [[ -z "${match}" ]] ; then
echo "${line}"
else
cron_fields=$(echo "${line}" | cut -f1-6 -d' ')
cron_job_dir=$(echo "${match}" | awk '{print $NF}')
if [[ -d "${cron_job_dir}" ]] ; then
for cron_job_file in "${cron_job_dir}"/* ; do # */ <not a comment>
[[ -f "${cron_job_file}" ]] && echo "${cron_fields} ${cron_job_file}"
done
fi
fi
done;
}
# Temporary file for crontab lines.
temp=$(mktemp) || exit 1
# Add all of the jobs from the system-wide crontab file.
cat "${CRONTAB}" | clean_cron_lines | lookup_run_parts >"${temp}"
# Add all of the jobs from the system-wide cron directory.
cat "${CRONDIR}"/* | clean_cron_lines >>"${temp}" # */ <not a comment>
# Add each user's crontab (if it exists). Insert the user's name between the
# five time fields and the command.
while read user ; do
crontab -l -u "${user}" 2>/dev/null |
clean_cron_lines |
sed --regexp-extended "s/^((\S+ +){5})(.+)$/\1${user} \3/" >>"${temp}"
done < <(cut --fields=1 --delimiter=: /etc/passwd)
# Output the collected crontab lines. Replace the single spaces between the
# fields with tab characters, sort the lines by hour and minute, insert the
# header line, and format the results as a table.
cat "${temp}" |
sed --regexp-extended "s/^(\S+) +(\S+) +(\S+) +(\S+) +(\S+) +(\S+) +(.*)$/\1\t\2\t\3\t\4\t\5\t\6\t\7/" |
sort --numeric-sort --field-separator="${tab}" --key=2,1 |
sed "1i\mi\th\td\tm\tw\tuser\tcommand" |
column -s"${tab}" -t
rm --force "${temp}"
Необходимо было бы выполнить это как корень, но:
for user in $(cut -f1 -d: /etc/passwd); do crontab -u $user -l; done
циклично выполнится по каждому имени пользователя, перечисляющему их crontab. crontabs принадлежат соответствующим пользователям, таким образом, Вы не будете в состоянии видеть crontab другого пользователя w/o быть ими или корнем.
<час> Редактирование , если Вы хотите знать, которому принадлежит пользователь crontab, используйте echo $user
for user in $(cut -f1 -d: /etc/passwd); do echo $user; crontab -u $user -l; done
Зависит от Вашей версии крона. Используя крон Vixie на FreeBSD, я могу сделать что-то вроде этого:
(cd /var/cron/tabs && grep -vH ^# *)
, если я хочу его больше вкладки deliminated, я мог бы сделать что-то вроде этого:
(cd /var/cron/tabs && grep -vH ^# * | sed "s/:/ /")
, Где это - литеральная вкладка в sed заменяющей части.
Это может быть более системно-независимо, чтобы циклично выполниться через пользователей в /etc/passwd
и сделать crontab -l -u $user
для каждого из них.
Под Ubuntu или debian, можно просмотреть crontab /var/spool/cron/crontabs/
, и затем файл для каждого пользователя там. Это только для определенного для пользователя crontab's, конечно.
Для Redhat 6/7 и Centos, crontab находится под /var/spool/cron/
.
Спасибо за этот очень полезный сценарий. У меня были небольшие проблемы с его запуском на старых системах (Red Hat Enterprise 3, которые по-разному обрабатывают egrep и табуляции в строках) и других системах, в которых ничего не было в /etc/cron.d/ (затем скрипт завершился с ошибкой). Итак, вот патч, чтобы заставить его работать в таких случаях:
2a3,4
> #See: http://stackoverflow.com/questions/134906/how-do-i-list-all-cron-jobs-for-all-users
>
27c29,30
< match=$(echo "${line}" | egrep -o 'run-parts (-{1,2}\S+ )*\S+')
---
> #match=$(echo "${line}" | egrep -o 'run-parts (-{1,2}\S+ )*\S+')
> match=$(echo "${line}" | egrep -o 'run-parts.*')
51c54,57
< cat "${CRONDIR}"/* | clean_cron_lines >>"${temp}" # */ <not a comment>
---
> sys_cron_num=$(ls /etc/cron.d | wc -l | awk '{print $1}')
> if [ "$sys_cron_num" != 0 ]; then
> cat "${CRONDIR}"/* | clean_cron_lines >>"${temp}" # */ <not a comment>
> fi
67c73
< sed "1i\mi\th\td\tm\tw\tuser\tcommand" |
---
> sed "1i\mi${tab}h${tab}d${tab}m${tab}w${tab}user${tab}command" |
Я не совсем уверен, что изменения в первом egrep - хорошая идея, но что ж, этот скрипт был протестирован на RHEL3,4,5 и Debian5 без любая проблема. Надеюсь, это поможет!
Мне нравится простой однострочный ответ выше:
для пользователя в $ (cut -f1 -d: / etc / passwd); сделать crontab -u $ user -l; done
Но Solaris не имеет флага -u и не печатает проверяемого пользователя, вы можете изменить его следующим образом:
for user in $(cut -f1 -d: /etc/passwd); do echo User:$user; crontab -l $user 2>&1 | grep -v crontab; done
Вы получите список пользователей без ошибок, выданных crontab, когда учетная запись запрещено использовать cron и т. д.Имейте в виду, что в Solaris роли также могут находиться в / etc / passwd (см. / Etc / user_attr).
getent passwd | cut -d: -f1 | perl -e'while(<>){chomp;$l = `crontab -u $_ -l 2>/dev/null`;print "$_\n$l\n" if $l}'
Это позволяет не работать с passwd напрямую, пропускать пользователей, у которых нет записей cron, а для тех, у кого они есть, выводит имя пользователя, а также их crontab.
В основном, я опускаю это здесь, чтобы найти это позже, если мне когда-нибудь понадобится искать это снова.
Небольшая доработка ответа Кайла Бартона с улучшенным форматированием вывода:
#!/bin/bash
for user in $(cut -f1 -d: /etc/passwd)
do echo $user && crontab -u $user -l
echo " "
done