シェルスクリプト総合 その25©5ch.net
■ このスレッドは過去ログ倉庫に格納されています
0001名無しさん@お腹いっぱい。 転載ダメ©2ch.net
2015/08/14(金) 23:42:01.51□お約束
・特記なき場合はBourne Shell(/bin/sh)がデフォルトです。
bash/zsh/ksh/ashなどに依存する場合は明示しましょう。
Linuxユーザは/bin/shの正体がbashまたはdashなので特に注意。
FreeBSDユーザは/bin/shの正体がashなので注意。
v7 shに一番近くて、現役のshは、OpenSolaris由来のheirloom sh。
http://src.illumos.org/source/xref/illumos-gate/usr/src/cmd/sh/
http://heirloom.sourceforge.net/sh.html
・csh/tcshのシェルスクリプトは推奨されません。
(理由は「csh-whynot」でググれ)
・UNIXにはシェルスクリプトに便利な小さなコマンドがいろいろあります。
manや参考リンクを見ましょう。
aproposないしはman -kでそれらしい単語による簡単な検索もできます。
・シェルで使えるワイルドカード等は正規表現ではありません。
正規表現の話題はスレ違い(正規表現スレへ)
・シェルスクリプトのことをシェルってゆーな
□初心者へのアドバイス:
・適した道具を判断するのも頭の重要な使い方。シェルスクリプトよりも
awkまたはperlの方が適した処理にはそちらを使いましょう。
・知らないコマンドが出てきたらmanを引きましょう。
・思い通りに動かないときは、まずは sh -x でトレースしましょう。
□回答者への注意事項:
・シェルスクリプトでの処理方法を質問しているのに、よくわからずに
「そういうのはperl使いましょう」と回答するのはやめましょう。
安易にperlに逃げずにシェルスクリプトで処理するのが頭のいいやり方。
前スレ
シェルスクリプト総合 その24
http://peace.2ch.net/test/read.cgi/unix/1415634843/
0559名無しさん@お腹いっぱい。
2016/04/16(土) 15:25:19.31いかにもインフラの人間がいいそうなことだが、キミは開発側ではありえない助言をしている。
0560名無しさん@お腹いっぱい。
2016/04/16(土) 15:27:25.430561名無しさん@お腹いっぱい。
2016/04/16(土) 15:28:05.090562名無しさん@お腹いっぱい。
2016/04/16(土) 16:30:24.50万が一のためインフラ側で制限しないとダメなんだよ
それでもダメなときはダメだし
設計・テストとかプログラムのみでの対応はコストだけが跳ね上がるし現実的ではない
ジョブ管理システムやコンパイラのバグが絡んでくるともうお手上げになる
0563名無しさん@お腹いっぱい。
2016/04/16(土) 18:08:55.670564名無しさん@お腹いっぱい。
2016/04/16(土) 19:49:59.880565名無しさん@お腹いっぱい。
2016/04/17(日) 01:23:14.240566名無しさん@お腹いっぱい。
2016/04/17(日) 07:15:51.53rm -rfはシェル関数で。直接使う事は禁則。
rmしないでmv。定期的に掃除
0567名無しさん@お腹いっぱい。
2016/04/18(月) 20:09:07.34http://japanese.engadget.com/2016/04/15/rm-rf-qanda/
0568名無しさん@お腹いっぱい。
2016/04/18(月) 20:24:48.32__
タヒんでしまえよ
0569名無しさん@お腹いっぱい。
2016/04/18(月) 22:44:34.250570名無しさん@お腹いっぱい。
2016/04/25(月) 19:04:26.09を作りたいのですが、引数の展開をどうやればいいかで悩んでいます。
# 例:sc tail -f ./hoge.log
sc() {
# "cd $PWD; $@"ではダメだった
screen -t "$1" -X screen bash -c "cd $PWD; '$1' '$2' '$3' '$4' '$5' '$6' '$7' '$8' '$9'"
}
10個以上の引数に対応するにはどう書くのがいいでしょうか?
0571名無しさん@お腹いっぱい。
2016/04/25(月) 21:45:04.21"cd $PWD; $@" だと screen のコマンド全体が、
"screen" "-t" "$1" "-X" "screen" "bash" "-c" "cd $PWD; $1" "$2" ...
という引数に展開される。
これは "cd $PWD; $@" がまず、"cd $PWD; ""$@" に変換され、
"$@" が "$1" "$2" ... に展開されて
"cd $PWD; ""$1" が連結されて "cd $PWD; $1" になるため。
なお set - "$@" cd "$PWD" ";" "$@" したら、 screen に渡るのは ; までで肝心のコマンドは渡らない。
"cd $PWD; $*" だと "cd $PWD; $1 $2 $3 ..." (配列としては展開されずに1つの文字列扱いになる)
に展開されて意図した動きになる。 ただ、引数に空白が入る場合はエスケープ入れないとNGね。
0572570
2016/04/26(火) 19:09:31.050573名無しさん@お腹いっぱい。
2016/04/26(火) 19:43:17.56シングルクォートと空白の例。
sc() {
screen -t "$1" -X screen bash -c "cd $PWD; $*"
}
sc date +Date=\\\'%y\\\ %m/%d
0574名無しさん@お腹いっぱい。
2016/04/27(水) 12:24:16.19与えたスクリプトの中で、展開すれば?
sh -c 'some command; "$@"' 'dummy' "$@"
sc() {
screen -t "$1" -X screen bash -c 'cd $PWD; "$@"' 'dummy' "$@"
}
0575570
2016/04/27(水) 19:13:45.99ちなみに
screen -t "$1" -X screen bash
は冗長で
screen -t "$1" bash
でいいみたいでした。
0576名無しさん@お腹いっぱい。
2016/04/27(水) 21:07:51.80これは -c AAA BBB CCC DDD ... のとき、BBB 以降は実行されないけど BBB が $0 として、
CCC DDD ... が引数としてセットされた状態でプロセスが開始され、実際に実行される内容の
AAA 内に展開されずに渡された "$@" があるので CCC DDD ... が実行されるってことかな。
ちなみに cd の部分は 'cd "'"$PWD"'"; "$@"' の方がいいかな。
( パスに空白が入っていてもエラーにならないがダブルクォーテーションが入っていたらNGではあるが。 )
0577名無しさん@お腹いっぱい。
2016/05/12(木) 21:13:45.79例えば、「*」がくるくると回っていたり・・・
0578名無しさん@お腹いっぱい。
2016/05/13(金) 00:30:46.450579名無しさん@お腹いっぱい。
2016/05/13(金) 19:21:12.15難しい…どなたかヒントを
0580名無しさん@お腹いっぱい。
2016/05/13(金) 20:19:09.81なんだよ、すごい目算があって開発宣言したと期待してたのに
まず、文字回すのは無理
/|\-を同じ位置で順番に繰り返す出す程度
あと、コマンド実行中は通常シェルはwait状態で止まってしまうので
コマンドをバックグラウンドで起動してシェルを動かし続けるか
別プロセスを同時に起動してそいつに表示させる必要がある
どっちもコマンドラインで明示しなきゃならん
普通に起動して同じことをさせるにはシェルの改造くらいしか思いつかん
それともzshくらいになるとすごいモジュールがあったりするのだろうか
0581名無しさん@お腹いっぱい。
2016/05/13(金) 20:43:34.110582名無しさん@お腹いっぱい。
2016/05/13(金) 20:57:15.29sleep 10 & {
tput civis
while kill -0 %- &>/dev/null
do
for c in {-,/,\|,\\}
do
printf '%c\r' $c
sleep 0.1
done
done
tput cvvis
}
途中で interrupt されるとカーソルが見えないままになるけど
0583名無しさん@お腹いっぱい。
2016/05/14(土) 20:15:01.860584534
2016/05/21(土) 22:04:30.88お陰さまで最低限現場の記述ルールに則ったものは普通に作れるようになりましたm(_ _)m
0585名無しさん@お腹いっぱい。
2016/05/23(月) 00:15:19.48超遅レスだかインフラでも
そんな事言わないあり得ない偏見すごいな
>>558
が伝えたいニュアンスは分かるけど
端的に考え方を言い表したいがために
登場場面が根本的に違う2つの用語だけで
端的に伝えようとするセンスが酷い
それにそもそも元の話と何かズレてるし
後輩育成とかは絶対に任せられないタイプ
0586名無しさん@お腹いっぱい。
2016/05/23(月) 08:05:15.40元ファイルをコピーしてヌルを上書きすると
一瞬ログの内容ロストするから
0587名無しさん@お腹いっぱい。
2016/05/23(月) 08:55:28.11ログを出す側で制御 (SIGHUPとかで出力ログファイルを開きなおす) してくれないとその問題は防げない。
mkfifo で FIFO ファイル作ってログローテーション用後続スクリプトに一旦渡す方法やパイプで後続スクリプトに
渡してローテーションする方法も考えられるけど、FIFO のバッファがいっぱいになるとメインプロセス側が処理
待ち(write がブロック)したり、後続スクリプトの異常終了で SIGPIPE 食らってメインプロセスが死んだりする
のでお勧めできないそうな。
0588名無しさん@お腹いっぱい。
2016/05/23(月) 16:33:22.230589名無しさん@お腹いっぱい。
2016/05/23(月) 17:04:28.650590587
2016/05/23(月) 23:22:16.85syslogd がつかんでいるのはファイルハンドルであってファイルのパスじゃない。
なのでそれをやっても、リネームした古いファイルの方に書き続けてしまう。
例えば /var/log/messages に書き続けている状態でファイルを mv して messages.1 にしても、syslogdは
messages.1 の方に書き続ける。
kill -HUP するとファイルハンドルを閉じて /var/log/messages を開くので、ここでようやく messages 側に書き始めるわけ。
# STOP/CONT は意味がない。 logrotate では syslogd のログについては HUP しかしない。
>>589
logrotate の samba のログ設定には copytruncate って書いてあるでしょ?
つまり logrotate が >> 586 の言う「コピーしてファイルを空にする」処理をやっている。
samba は syslogd のような開きなおす処理をしてくれないからこの実装にせざるを得ない。
0591名無しさん@お腹いっぱい。
2016/05/24(火) 04:38:11.44kill -HUP に対応してないsyslogdだったら、という話だろ。
kill -STOP してからログファイルを別ファイルにcpして、元のログは > file でゼロにする。
それで -CONT すればいいという話。
>syslogd がつかんでいるのはファイルハンドルであってファイルのパスじゃない。
というのは当然知ってるだろ。
0592名無しさん@お腹いっぱい。
2016/05/24(火) 08:44:45.64STOP -> truncate -> CONT って安全?
TCP/UDPで待ち受けしているプログラムで syn やメッセージ取りこぼしたりとかしない?
fork する奴にも使える?
0593名無しさん@お腹いっぱい。
2016/05/24(火) 09:37:37.23TCPなら再送含めてOSがうまくやる
UDPだとバッファあふれたら消える
もともと消えるの前提だから再送はアプリの自己責任
forkしたら止まるのは当たり前だが指定したプロセスだけ
プロセスグループを指定したら該当するやつ全部
どの辺が疑問なのかむしろ知りたいわ
0594592
2016/05/24(火) 20:11:40.98THX
> どの辺が疑問なのかむしろ知りたいわ
logrotate コマンドの copytruncate の欄に SIGSTOP すると良い、とは書かれていない
あたり、何か不都合があるんじゃないかと思うんだがどーよ?
0595名無しさん@お腹いっぱい。
2016/05/24(火) 22:53:24.96そいつとtcpもudpもforkも関係ないのになんで出てきた?
0596名無しさん@お腹いっぱい。
2016/05/25(水) 08:40:27.70ちょっとした間にサービス停止として検知される可能性があるな。
0597名無しさん@お腹いっぱい。
2016/05/25(水) 15:06:05.265分って、どこの標準か興味がある。
0598名無しさん@お腹いっぱい。
2016/05/27(金) 20:10:08.30普通は単純にリネームしてタッチする
0599名無しさん@お腹いっぱい。
2016/05/28(土) 12:10:25.230600名無しさん@お腹いっぱい。
2016/05/29(日) 01:58:44.160601名無しさん@お腹いっぱい。
2016/05/29(日) 20:46:35.04特定のコマンドやシェルのノウハウとかではなく
多くの場面で通用する本当に基礎的な知識を学びたいと思っています
私自身はいずれシェルを書きたいと思っていますが
LS、CPコマンドなどの使い方を知りたいわけではないということです
0602名無しさん@お腹いっぱい。
2016/05/29(日) 20:57:27.92UNIXスーパーテキスト
ってまだ売ってたっけ?
0603名無しさん@お腹いっぱい。
2016/05/29(日) 21:40:46.70古い本だけど砂原秀樹さんほかの『プロフェショナルBSD』
UNIXのコマンドはこういうふうに使うという根本的なことの理解に役立つ
0604名無しさん@お腹いっぱい。
2016/05/29(日) 22:26:33.910605名無しさん@お腹いっぱい。
2016/05/29(日) 23:19:55.20入門UNIXシェルプログラミング―シェルの基礎から学ぶUNIXの世界
名著です。
これを挙げると古いとか文句を付ける馬鹿がいますが、無視してください。
0606名無しさん@お腹いっぱい。
2016/05/29(日) 23:20:36.490607名無しさん@お腹いっぱい。
2016/05/30(月) 00:14:11.32お前の心が汚れているだけだ
0608名無しさん@お腹いっぱい。
2016/05/30(月) 03:08:51.89[1] Done emacs
って出るよな?これって何が出しているんだろう?出来れば止めたい。
0609名無しさん@お腹いっぱい。
2016/05/30(月) 04:52:05.02set +m しておくと出なくなるよ。(出してるのはシェル自身)
0610名無しさん@お腹いっぱい。
2016/05/30(月) 09:25:10.53する方法はないでしょうか?
vimプラグインのsyntasticも試してみたのですが、.vimrcの記述のせいか
うまく動いてないようで。
何か簡単でうまい方法ありましたら、ご紹介ください。
0611名無しさん@お腹いっぱい。
2016/05/30(月) 10:19:27.79どうもです。なるほどシェルが出しているのですか。
でも、なぜ emacs しか出ないのでしょう?
教えていただいた set +m 「ジョブ制御の無効」は bash のみでしょうか?
私は tcsh なのですが、tcsh でも同様の事は可能でしょうか?
0612名無しさん@お腹いっぱい。
2016/05/30(月) 18:00:07.40シェルで2つの日時を元に所要時間を求めたい場合ぐぐるといろいろ方法はありますが
これが便利なコマンド一発で用意されていないのは需要がないと言うか
需要があった人が最終的に誰でも使える簡単な形にせずに終わらせたってことなんでしょうか?
0613名無しさん@お腹いっぱい。
2016/05/30(月) 18:55:30.71広く使われるほどの需要はなかった
0614名無しさん@お腹いっぱい。
2016/05/30(月) 19:36:20.17GNU date限定とかならいいんだけど
0615名無しさん@お腹いっぱい。
2016/05/30(月) 21:40:48.250616名無しさん@お腹いっぱい。
2016/05/31(火) 08:52:48.3032bitマシンが絶滅するまでは難しいな。
あと20年普通に残りそうだし
0617名無しさん@お腹いっぱい。
2016/05/31(火) 21:45:59.92内部というのは環境変数やシェル変数という意味?
0618名無しさん@お腹いっぱい。
2016/05/31(火) 23:23:59.980619名無しさん@お腹いっぱい。
2016/05/31(火) 23:24:37.85epochからの時間ってことじゃない?
>>616
difftime(3)て32bitと64bitで違うのかな
0620超音波テロの被害者
2016/06/01(水) 16:02:45.59卑劣極まりない被害にあっています。
何が起こったかわからないときから、
わかってみれば、
まだ世の中に知られていない超音波テロ。
世の中の多数の振動源・発信源が
システム化され、 ネットワークを通して、
超音波・音波を集中させて
対象を攻撃するらしい。
超音波による物理的な力で、
ものが飛び、ものが壊れる。
それが人間の体に対してまで。
形のあるもの、ないもの、壊され、奪われ、
聞こえる声、音。超音波テロの加害者の声。
卑猥な内容、卑劣な内容、脅しやいたぶり。
0621超音波テロの被害者
2016/06/01(水) 16:03:08.53頭蓋骨を突き抜け、意識を失わされる。
臓器不全やがん、命に関わることまで。
人間の身体を壊そうとする超音波テロ。
日本国中、どこにいても超音波で襲われる。
車に乗っている人間が襲われる。
歩いている人間が襲われる。
自宅で超音波の攻撃を受ける。
人や社会が超音波で襲われ、
罪もない人が超音波で襲われ、
卑劣な被害にあっています。
被害を訴えても信じてもらえない。
「見続けるのがいやだから、殺して終わる」、
「証拠隠滅だ」という超音波テロの加害者の声とともに
強烈な超音波の攻撃。
叫ばされ、いたぶられ、それを口実にまた攻撃され、
超音波テロの、残酷残虐で、卑劣な攻撃の被害にあっています。
心の底から被害を訴え、祈っています。
天に神に届きますように。
0622名無しさん@お腹いっぱい。
2016/06/01(水) 17:45:47.97これなんつーシェルのスクリプトですか?
0623名無しさん@お腹いっぱい。
2016/06/02(木) 07:52:05.220624名無しさん@お腹いっぱい。
2016/06/02(木) 08:00:02.530625名無しさん@お腹いっぱい。
2016/06/05(日) 11:03:53.19にすべきか、最後の/をつけるかつけないかでどんな違いがあるのか
いつもすごく気になる。
0626名無しさん@お腹いっぱい。
2016/06/05(日) 13:34:06.57rsync や ln 、mv あたりはありなしで挙動がかわる。
ln や mv はオプションで一応制御できるけど
0627名無しさん@お腹いっぱい。
2016/06/09(木) 19:13:38.61いいスクリプト知りませんか?
jqはできそうな感じなんだけど、サンプルのページが見当たらなくて
0628名無しさん@お腹いっぱい。
2016/06/09(木) 21:10:02.49cpanモジュール使うべし。
力技でゴリゴリでもできるかもしらんが、時間の無駄
0629名無しさん@お腹いっぱい。
2016/06/09(木) 22:45:45.43データがどんなもんか分からないので何とも言えないけど例えば
[
{"id": 1, "name": "Tom", "gender": 1},
{"id": 2, "name": "Alice", "gender": 2},
{"gid": 1, "gender": "male"},
{"gid": 2, "gender": "female"}
]
なんてJSONファイルがあって gender と gid で join する場合、
jq '
map(
(select(has("id")) | { k: .gender, v: { id: .id, name: .name }}),
(select(has("gid")) | { k: .gid, v: { geder: .gender }})
)
| group_by(.k)
| map((map(.v) | add))
' data.json
かなぁ。
0630629
2016/06/10(金) 01:11:22.91jq '
(map(select(has("gid")) | {(.gid|tostring): .gender}) | add) as $g
|
map (select(has("id")) | .gender = $g[(.gender|tostring)])
' data.json
0631名無しさん@お腹いっぱい。
2016/06/10(金) 01:28:18.48{
"id": 1,
"name": "Tom",
"gender": "male"
},
{
"id": 2,
"name": "Alice",
"gender": "female"
}
]
できました、できましたけど書き方わからないです><
>>628
cpan使うのが主流なんですか?
0632名無しさん@お腹いっぱい。
2016/06/10(金) 01:54:22.40json 形式のデータを DB に insert する方法を調べた方がいいかも
0633名無しさん@お腹いっぱい。
2016/06/10(金) 14:14:19.71いやそういうわけではなくて、pythonでもrubyでもいいけど
JSONとかXMLとかYAMLなどの定形式な文書からスライスして取
り出すなら、すでにある専用モジュールとか使ったほうが断然
速いってはなし。俺はperlしかわからんのでcpanモジュール。
perlなら
use JSON::XS;
して、
my $json = 'json.txt'
my $data = decode_json($json); #jsonからperlのハッシュに変換
あとは、ハッシュの内容をダンプしてデータ構造みながら
必要なデータだけを拾う。
print %$data{features}->[$cnt]->{properties}->{title} .
0634名無しさん@お腹いっぱい。
2016/06/10(金) 16:33:17.980635名無しさん@お腹いっぱい。
2016/06/10(金) 22:15:34.82なんでもありなら今はPythonの方がメジャー
もしくはRubyとか
0636名無しさん@お腹いっぱい。
2016/06/10(金) 23:07:20.19gomプレイヤーとかのソフト立ち上げるとスクリプトエラー出るんだけどどうしたらいい?
http://imgur.com/9hlJu8w
0637名無しさん@お腹いっぱい。
2016/06/11(土) 00:12:44.310638名無しさん@お腹いっぱい。
2016/06/11(土) 00:34:35.87↓
にちゃんでスクリプトで検索
↓
シェルスクリプトとかよくわからんけどスクリプトって入ってるからここに書けば誰か完璧な答えを出してくれるはず
ゆとり、ここに極まれり
0639名無しさん@お腹いっぱい。
2016/06/11(土) 03:40:49.780640名無しさん@お腹いっぱい。
2016/06/11(土) 03:41:43.140641名無しさん@お腹いっぱい。
2016/06/11(土) 03:53:01.79こんな感じなのだろうか。
0642名無しさん@お腹いっぱい。
2016/06/11(土) 04:14:09.33こんな感じで良いのかな?
find 引数 -maxdepth 0 -name *.sh -exec bin/sh -c ' {} ' \;
0643名無しさん@お腹いっぱい。
2016/06/11(土) 10:22:42.970644名無しさん@お腹いっぱい。
2016/06/12(日) 05:31:11.760645名無しさん@お腹いっぱい。
2016/06/12(日) 11:11:52.76for input in *
do
(処理)
done
これだと映像ファイルだけでなく全てのファイルが対象になってしまいます。
そうではなくて WMV、MP4、AVI、MPEG、MPGといった映像ファイルだけを
処理するにはどうしたらいいでしょうか?
0646名無しさん@お腹いっぱい。
2016/06/12(日) 11:15:55.66そもそもなんでファイルを振り分けてないのか?
0647名無しさん@お腹いっぱい。
2016/06/12(日) 11:25:58.85ffmpegで処理してるので映像ファイルの種類は分けなくても良かったりします
あ、ただ変換後の拡張子は統一するようスクリプトを書かないといけませんね
0648名無しさん@お腹いっぱい。
2016/06/12(日) 11:44:06.36for input in $(ls -1 *.{wav,mp4,avi,mpeg,mpg} 2>/dev/null)
do
(処理)
done
とか。
0649名無しさん@お腹いっぱい。
2016/06/12(日) 11:52:44.28これじゃダメな場合があるんだっけ?
for input in *.wav *.mp4 *.avi *.mpeg *.mpg
do
〜
done
0650名無しさん@お腹いっぱい。
2016/06/12(日) 12:07:38.74だけど、ループの中で処理する時に
[ -f "$input" ] || continue
とでもしとけばいいよね
0651名無しさん@お腹いっぱい。
2016/06/12(日) 12:36:44.21>>650
なるほど、そういう方法がありましたか。
ありがとうございますm(_ _)m
>>649
>>650さんのご指摘通りその拡張子のファイルが無いとそのまま入っちゃうって問題がありますね
0652名無しさん@お腹いっぱい。
2016/06/13(月) 20:14:40.91改行を追加するようなスクリプトってどう書けばいいでしょうか?
0653名無しさん@お腹いっぱい。
2016/06/13(月) 22:21:10.97それ、自分が前悩んで作ったのがある。誰か改善してくれ
#!/bin/sh
file=$1
test -f $file || exit 0
# if size -eq 0; then exit 0
if [ ! -s $file ]; then
exit 0
fi
# if the last character is not \n, then echo
if [ "$(tail -c 1 $file | cat -A)" != "$" ]; then
echo
fi
if ! tail -n 1 $file | grep '^$' > /dev/null ; then
echo
fi
0654名無しさん@お腹いっぱい。
2016/06/13(月) 22:23:13.080655652
2016/06/13(月) 22:28:48.20だから>>652さんの求めているスクリプトとはちょっと違った_o_
0656名無しさん@お腹いっぱい。
2016/06/13(月) 22:49:39.12ファイルがぶっ壊れちゃったじゃないか(#゚Д゚) ゴルァ!!
なんつって
0657名無しさん@お腹いっぱい。
2016/06/13(月) 22:58:56.61ありがとうございます
最終文字を取り出して調べるというわけですね
いじれそうです
たぶんGNUのtailが必須じゃないかと思うのですが、
非GNU環境でも動くようにはならないでしょうか
0658名無しさん@お腹いっぱい。
2016/06/13(月) 23:07:30.48ありがとうございます
ただ、これは目的の動作ではありません
末尾に空行が欲しいのではなく、
改行文字で終わっていない最終行に改行をつけたいのです
0659名無しさん@お腹いっぱい。
2016/06/14(火) 00:26:19.34#!/bin/sh
echo wq | ed "$1"
■ このスレッドは過去ログ倉庫に格納されています