ラベル スクリプト の投稿を表示しています。 すべての投稿を表示
ラベル スクリプト の投稿を表示しています。 すべての投稿を表示

2012-06-06

簡単なbashスクリプト: 簡易ストップウォッチ

二つの時刻の間隔を計る簡易ストップウォッチ・スクリプトをBashで作ってみました。計測の単位は「sec」だけです。

#!/bin/bash

# mySec: A Stopwatch script
#
# usage:    mySec 0 ←     Start-time in unit of sec.
#            mySec   ←     Time-interval from Start-time in unit of sec.
#           mySec now ←    Current Time in unit of sec.
#
# example:
#            $ mySec 0; sleep 3;mySec    # Check#
#            3sec
#            $ mySec 0     # Start the Stopwatch
#            ... Somothing done ...
#            $ mySec     # Stop the Stopwatch
#            81sec
#            $mySec now    # Curent Time in unit of sec.
#            1339041714
#
# 2012-06-06  (水) 20:07, by mNeji

#set -x

if [ "$1" = "now" ]
then
# for "mySec now" ------------------------------------------------
    echo `date +%s`
    exit 0
fi

if [ -z $1 ]
then
# for "mySec" -----------------------------------------------------
    Stop=`date +%s`
    Start=`cat ${0}.start`
    time_interval=`expr ${Stop} - ${Start} `
    echo "${time_interval}sec"
    rm -f ${0}.start   
else
# for "mySec 0" --------------------------------------------------
    # echo `date +%s` | tee ${0}.start
    date +%s > ${0}.start
fi


【関連記事】
  1. 簡単なbashスクリプト 
  2. 外付けHDDの特定パーティションのマウント/アンマウント・スクリプト
  3. bashとpythonとの連携スクリプトで「du」を観易くする


ーーーー
このポストの履歴
  1. 開始: 2012-06-06-20:30(JST)
  2. 修正: 2012-06-07  (木) 13:06


2012-06-04

外付けHDDの特定パーティションのマウント/アンマウント・スクリプト

切っ掛けはアップルのサポートコミュニティ、Mac OS X v10.7 Lionでの論議;
で、「timeutil」コマンドを使えば、GUIの「Time Machine」の「今すぐバックアップを作成」を開ける事無く、CUIからのコマンドでバックアップを開始できると思えるようになった事だ。とりあえず最小のコマンド;
#! /bin/sh

# tmback: Manually execute "Time Machine Backup"
# 2012-05-04 by mNeji

echo "+ Script($0) start at `myDate` ++++++++++++++"
tmVol=`tmutil machinedirectory`
#echo "tmVol: ${tmVol};"
noVol=""
#echo "noVol: ${noVol};"

if [ "$tmVol" = "$noVol" ]; then
    echo "Please wakeup External HDD for Time Machine Backup, Try again!"
else
    echo "+ Time Machine Backu Up for `tmutil machinedirectory` "
    #echo "+ sudo tmutil uniquesize \`tmutil listbackups\` ---------------------"
    #sudo tmutil uniquesize `tmutil listbackups`
    echo "+ sudo tmutil startbackup --block  ---------------------------"
    sudo tmutil startbackup --block
    echo "+ sudo tmutil uniquesize \`tmutil listbackups\` ---------------------"
    sudo tmutil uniquesize `tmutil listbackups`
fi   
echo "+ Script($0) finish at `myDate` +++++++++++++"
echo
 で保存するようになった。かれこれ1ヶ月ほど安定的にバックアップがとれている。

問題は、手動でFinderを経由して外付けHDDの内の「Time Machine」のパーシションを起動する必要がある事だ。そこで、今回は『必要なパティション、$tmVol、をマウント/アンマウントするスクリプト』を作ろうと考えた。


手元の資料としては
であった。svensonさんの記事では「/Volumes/」でのパーティション名(partition name)もしくはヴォリューム名(volume name)とディバイス名(/dev/diskNsM)とを必要と読める。

でもユーザがFinderで認識してしているのは、あくまで「パーティション名(partition name)」なのだからと思い、「diskutil」を弄り回した。その結果;
  • 電源が入っている外付けのリストは「diskutil list」で確認できる。この中にパーティション名($NAME)があれば、次に進む。ここに無ければ電源の投入を注意する。
  • マウントの状況は「diskutil info $NAME」で判るが、直裁に「ls /Volumes」を取って、その中に$NAMEがあるかどうかで判定できる。
  • 具体的tmutilコマンドでは、パーティションはフルパス表現は不要の様子;
    • マウント: diskutil mount $NAME
    • アンマウント: diskutil umontDisk $NAME
      • 一部のアンマウントだけに止
      • めたければ、
      • 「umontDisk → umont」
とすれば善い事が判った。

そこでマウント用のHDDonと、アンマウント用のHDDoffとを作った;

マウント用のHDDon
#!/bin/bash

#
# usage: myHDDon Volume_Name
#              ↑ /Volues/に出てくるパーティション名(partition name)、ヴォリューム名(Volume name)。
#
#               引数なし(no argument)だと、get "diskutil list"
# 2012-06-03 by mNeji
#

# debug ################
# set -x

# Refered Information
# A bash script  to mount and unmount the Windows partition in Mac OS X
# http://forums.macrumors.com/showthread.php?t=195891

# Volume Name of the Partition
NAME=$1

# 無引数(no argument) ######################################
if [ -z $NAME ] ; then
    diskutil list
    exit 1
fi

# 引数(argument)=パーティション名(partition name in /Volumes/) ################

# /Volumes/中にパーティション$NAMEがあるかの判定
### p_name=`ls -1 /Volumes/ | grep ${NAME}`
### echo "p_name: '${p_name}'" # debugging output
if [ -z `ls -1 /Volumes/ | grep ${NAME}` ] ; then
    # パーティション$NAME が存在していない
    # check the $NAME in "'diskutil list'"
    ### echo "--> `basename $0`: Checking $NAME in "'diskutil list'" at `myDate`"
    if [ -z `diskutil list | grep " $NAME " | awk '{print $3}'` ] ; then
        # no $NAME in "diskutil list"
        echo "--> `basename $0`: Turn on POWER SW and Retry ----------------"
        diskutil list
        echo "--> `basename $0`: Turn on POWER SW and Retry ----------------"
        exit 1
    else
        # already Powerd the HDD, then mounting
        diskutil mount $NAME > /dev/null
        ### echo "--> `basename $0`: '${NAME}' mounted now."
        exit 0
    fi
else
    # already mounted the partition
    ### echo "--> `basename $0`: '${NAME}' mounted already."
    exit 0
fi


  アンマウント用のHDDoff
#!/bin/bash

#
# usage: myHDDoff Volume_Name
#              ↑ /Volues/に出てくるパーティション名。
#              そのVolune_Nameのmount/unmoutのトグル・スイッチ
#
#               引数なし(no argument)だと、get "diskutil list"
# 2012-06-03 by mNeji
#

# debug ################
### set -x

# Refered Information
# A bash script  to mount and unmount the Windows partition in Mac OS X
# http://forums.macrumors.com/showthread.php?t=195891

# Volume Name of the Partition
NAME=$1

# 無引数(no argument) ######################################
if [ -z $NAME ] ; then
    diskutil list
    exit 1
fi

# 引数(argument)=パーティション名(partition name in /Volumes/) ################
# p_name=`ls -1 /Volumes/ | grep ${NAME}` # for debugging
# echo "p_name='${p_name}'"

# Check existing of directory of /Volumes/$NAME ##############
partition_name=`ls -1 /Volumes/ | grep ${NAME}`
if [ -z ${partition_name} ] ; then
# there is no /Volumes/$NAME:
    # check the $NAME in "'diskutil list'"
    ### echo Checking $NAME in "'diskutil list'" at `myDate`
    if [ -z `diskutil list | grep " $NAME " | awk '{print $3}'` ] ; then
        # no $NAME in "diskutil list"
        echo "--> `basename $0`: Confirm Volume(Partition)-name! ----------------"
        diskutil list
        echo "--> `basename $0`: Confirm Volume(Partition)-name! ----------------"
        exit 1
    fi     
else
# there is /Volumes/$NAME:
    # unmounting the its all Disk
    diskutil unmountDisk $NAME >/dev/null
    ##### echo "--> `basename $0`: '${NAME}' unmounted Disk now."
    exit 0
fi
なお、判定文の”[  -n $string ]"は上手く動かなかったので、仕方なく”[  -z $string ]"のタイプに統一しました。

ーーーー
  1. 開始 2012-06-04  (月) 12:53 
  2. 修正 2012-06-05  (火) 13:38  「HDDoff: partition_name」←「binary operator expected」対策

2012-04-09

bashとpythonとの連携スクリプトで「du」を観易くする

最近、「python shell」でpythonの練習をしていると、ちょっと複雑なスクリプトをチューニングしようとすると、Aquamacsで.pyとして書き出し、terminalで動作確認する方が楽である事に気がついた。

慣れるにつれて、bashもpythonもターミナルから見ればスクリプトである事を実感して来た。数値処理は、若い頃にFortranやHP-BASICなどを使っていた事も在り、bashでやるよりはpythonの方が使い易い事にも気がついた。

そんな折り、「Time machine」によるバックアップに並行して、ディレクトリごとのバックアップ(rsync)をしたいと思うようになった。ついては以前、iMac間で、データの転送する時に、「du -h -d 1」をして、印刷用紙上で、転送の有無と、サイズの確認をしたものの見辛かったのを思い出した。

今回は、このコマンドをサイズの大きい順にソートして、「-h」に近い形式で見易くする事を考えた。大部分は下記の参考書を見ると、bashでできる;
  •  UNIXシェルスクリプト 逆引き大全 333の極意
    • 中橋 一郎・著
    • 秀和システム、2009-08.
    • ISBN-10: 4-7980-0884-2
が、計算処理はpythonの方が楽そうだ。そこで、bashスクリプトからpythonスクリプトを「バックコートで括る」形式で読みだす事にトライした。

まず、bashスクリプト本体は;

u1@div-mm:~/bin$ cat myDU
#!/bin/bash 

# Finderで、ディレクトリ右クリックで「情報」を見るのは面倒だ。そこで
# 現在のディレクトリ中の全てのディレクトリのサイズを求め、
# ブロックの順にソートし、
# バイト単位(kB=1000B, MB=1000kB, GB=1000MB)で表示する。
#    2012-04-08  (日) 15:44 by mNeji/irt
#    on Lion/10.7.3 at Mac mini(mid 2011)

# 参考: 「UNIXシェルスクリプト 逆引き大全 333極意」
#          中橋 一郎 著
#          秀和システム、2009-08
#          ISBN-10:4-7980-0886-2
# 参考箇所:unix333, (p223, Tips#194), (p112, Tips#084)

# 説明の表示
echo "+ Script($0) at `myDate` start +++++"
echo "+ action: 'du -d 1 | sort -gr' for dir:'`pwd`' " 
printf '+ Size \t\t Directory Name ----------------------\n'

# 現在のディレクトリと直下のディレクトリのサイズを求め、ブロックの順にソートする
du -d 1 |sort -gr > temp_du

# unix333, (p223, Tips#194): ファイルを行に分割
IFS=$'\n'               #改行区切り 
file=(`cat temp_du`)    #fileはアレイ構造

rm -f temp_du           # 中間ファイルを削除

# アレイの第一列にあるブロック数を適切なバイト数に変換して、
# 表として再度、表示する。

for line in "${file[@]}";do

    # unix333, (p112, Tips#084): 1行をタブで分割
    IFS=$'\t'       #タブ区切り
    set -- $line    #$1はブロック数(512Byte) , $2は相対ディレクトリ 
 
    #ブロック数からkByte, MByte, GByteへの変換には、
    #「Python script: myBlock2Byte.py」を作成して、用いた。
    ByteSize=`myBlock2Byte.py "$1"`  
    
    # 行表示
    printf '%s\t %s\n' "$ByteSize" "'$2'"

done

echo "+ Script($0) at `myDate` stop +++++"
u1@div-mm:~/bin$ 


ここで、「pythonスクリプトの呼び出し」は第42行目の;

  • ByteSize=`myBlock2Byte.py "$1"`

です。

 そのpythonスクリプト「myBlock2Byte.py」は;

u1@div-mm:~/bin$ cat myBlock2Byte.py 
#! /usr/bin/python
# coding: utf-8

# usage: $ myBloch2Byte.py block_number
#         The parameter, block_number indicates in the unit of 1block = 512Byte

# input: Size in the unit of Block
# output: Size in the unit of kB, MG, GB
# 2012-04-06 by mNeji
#   Python/2.7.1 on Lion/10.7.2 at Mac mini(mid 2011)


# 引数の受け入れ
import sys
myArg= sys.argv

# ブロック数を整数型に変換し、
blockSize=int(myArg[1])

# module math
import math

# バイト数に変換
byteSize=math.floor(blockSize*512)  # 1block = 512Byte
kSize=byteSize/1000.    # 1kB = 1000Byte for Lion/10.7.3
MSize=kSize/1000.       # 1MB = 1000kB for Lion/10.7.3
GSize=MSize/1000.       # 1GB = 1000MB for Lion/10.7.3



# 使用サイズの補助単位選択

if GSize >= 1.:
    print '%7.2f%s' % (GSize,"GB")
elif MSize >= 1.:
    print '%6.1f%s' % (MSize,"MB")
else:
    print '%5.0f%s\t' % (kSize,"kB")


    
u1@div-mm:~/bin$ 



です。

このスクリプトで自分のホーム・ディレクトリのディレクトリ容量を出した結果は;

u1@div-mm:~$ myDU
+ Script(/Users/u1/bin/myDU) at 2012-04-09(月)14:02:28 start +++++
+ action: 'du -d 1 | sort -gr' for dir:'/Users/u1' 
+ Size    Directory Name ----------------------
 129.61GB  '.'
  64.22GB  './Library'
  57.51GB  './Music'
   5.76GB  './VirtualBox VMs'
 714.6MB  './Sites'
 564.1MB  './Documents'
 465.9MB  './Pictures'
 143.2MB  './myLocal'
 111.6MB  './Kabe-Gamis'
  88.3MB  './tmp'
  11.5MB  './bin'
   8.3MB  './backup'
   4.6MB  './.npm'
   2.9MB  './.gem'
   1.4MB  './myBash'
   1.3MB  './RRwork'
   1.1MB  './solarized'
  569kB   './Public'
  172kB   './.zsh.d'
  164kB   './DLしたプログラム資料'
   66kB   './function'
   53kB   './zsh_back0'
   20kB   './.ssh'
   16kB   './mytest'
   16kB   './Downloads'
   16kB   './Desktop'
    4kB   './.pip'
    4kB   './.idlerc'
    4kB   './.cups'
    0kB   './NTT_PR-S300SE'
    0kB   './Movies'
    0kB   './.emacs.d'
    0kB   './.bundler'
    0kB   './.Trash'
+ Script(/Users/u1/bin/myDU) at 2012-04-09(月)14:02:30 stop +++++
u1@div-mm:~$ 

です。なお、上記の容量値を、Finderで該当するディレクトリを右クリックして情報を見てみますと;




サイズの項にでている「129.61 GB」 と一致します。それぞれ小さい場合も完全に一致しています。今後、気楽にバックアップを検討する事ができそうです。


慣れてしまえば、完全にpythonスクリプトで処理する方が楽そうである。いよいよ、Calcのマクロをpythonで作る事も可能な気がして来た。



ーーーー このポストの履歴
  1. 開始 2012-04-09 (月) 13:53


2012-03-25

簡単なbashスクリプト

自分のネットワーク環境を整備する為に、幾つかのスクリプトを作りました。忘れる前にメモしておきます。
  1. myDate: 自分のタイムスタンプ
  2. myHost: 自分のマシンのホスト名、localhostのIPアドレス
  3. myNet: 自分のマシンが属するネットワーク情報
  4. myScanIP: PINGを連続的にスキャンする。
  5. myDiskutil_list: 「diskutil list」のまんま
  6. myMount_disk1: 外付けhdd, disk1のマウント
  7. myUnmount_disk1: 外付けhdd, disk1のアンマウント
この内、1〜4は便利なので、公開しておきます。

1 myDate
#!/bin/bash
date +'%Y-%m-%d(%a)%H:%M:%S'

2 myHost
#!/bin/bash
#
# myHost: 動作例=>「HOST: name=(div-mm.local); ip=(10.0.1.2)」 
#
# 参考: UNIXシェルスクリプト 逆引き大全 333極意
#        p112, #84 文字列を指定した区切り文字で分割する。


getHostIP() {
 hostName=`hostname`
 localIP=`netstat -r -f inet |grep "localhost" | grep "UHS"`

 _IFS="$IFS"    # save $IFS
 IFS=' '
 set -- $localIP
 IFS="$_IFS"

 # 分割結果:
 # $1: host's IP address
 # $2: localhost
 # $3: UHS
 
 echo "HOST: name=($hostName); ip=(${1})"
              
 return
}

# 実行
getHostIP

3. myNet
#!/bin/bash

echo '"netstat -r -f inet"'
echo " at `myDate`"
netstat -r -f inetdiv

4. myScanIP
#!/bin/bash
#
# myScanIP [ipSpace ipStart ipWidth ] 
#

#localIP=`netstat -r -f inet |grep localhost | grep UHS`
localIP=`myHost`
echo $localIP

declare -i j k ipStart ipStop ipWidth noa

j=1 #start
k=5 #width


# Default values
ipSpace="192.168.1"
ipStart=j
ipWidth=k
noa=$#

#echo "  Number of Arguments = $noa"
#echo "    ipSpace=${ipSpace}"
#echo "    ipStart=${ipStart}"
#echo "    ipWidth=${ipWidth}"

if [ $noa -eq 0 ]; then
    damy=1
elif [ $noa -eq 1 ]; then
    ipSpace=$1
elif [ $noa -eq 2 ]; then
    ipSpace=$1
    ipStart=$2
elif [ $noa -eq 3 ]; then
    ipSpace=$1
    ipStart=$2
    ipWidth=$3
fi

ipStop=$ipStart+$ipWidth-1


if [ $ipStop -gt 256 ]; then
    ipStop=255
    ipWidth=ipStop-ipStart+1
fi


file="ipScan_${ipSpace}.${ipStart}~${ipStop}.txt"
echo "======= myScanIP for ${ipSpace}.${ipStart}~${ipStop}" > $file
echo "===== ping from ${localIP}" >> $file
echo "  Number of Arguments = $noa" >> $file
echo "    ipSpace=${ipSpace}" >> $file
echo "    ipStart=${ipStart}" >> $file
echo "    ipStop=${ipStop}" >> $file
echo "    ipWidth=${ipWidth}" >> $file
echo "=== save file:'${file}'" >> $file

timeStamp=`date +'%Y-%m-%d(%a)%H%M%S'` 

echo "* Scan start:_${timeStamp} " >> $file

echo "======= scanIP for ${ipSpace}.${ipStart}~${ipStop} =============="

echo "===== ping from ${localIP}"

echo "  Number of Arguments = $noa"
echo "    ipSpace=${ipSpace}"
echo "    ipStart=${ipStart}"
echo "    ipStop=${ipStop}"
echo "    ipWidth=${ipWidth}"

echo "=== save file:'${file}' "
echo "* Scan start:_${timeStamp} "

j=ipStart

while [ $j -le $ipStop ];
do
    result=`ping -c 2  "${ipSpace}.$j"`
    yes_response=""
    yes_response=`echo "$result" |grep 'round-trip min/avg/max/stddev'`
    if [ "$yes_response" != "" ]; then
        echo "#ip=${j}: ${yes_response}"  >>$file
        echo "#ip=${j}: ${yes_response}"
    else
        echo  "_ip=${j}:non___" 
    fi
    j=j+1

done

timeStamp=`date +'%Y-%m-%d(%a)%H%M%S'` 
echo "* Scan stopped:_${timeStamp} " >> $file
echo "* Scan stopped:_${timeStamp} "

echo "========= myScanIP finished =============="

上記のスクリプトの28行目の「dummy=1」と言う無意味は命令は、本来コメント「#」でしたが、そうすると次の「elif」がエラーとなるので挿入しました。この経験から、現在zshへ乗り換えをしようとしています。

【関連記事】

  1.  
  2. 簡単なbashスクリプト: 簡易ストップウォッチ 

ーーーー このポストの履歴
  1. 開始 2012-03-25 (日) 13:59

注目の投稿

Terminalでの、なんちゃってViモドキ

近頃、ようやくKarabiner-Elementsに慣れてきたので、 Terminalで動作する「擬似Vi-Mode」を作って見たので、ご紹介します。 『概要』 「擬似Vi-Mode」の所以は、方向キー「←↓↑→」を通常の「hjkl」ではなくて「jkil」としました。これ...