シェルスクリプト総合 その30

■ このスレッドは過去ログ倉庫に格納されています
2019/07/01(月) 23:04:27.02ID:/rKj5XUf
シェルスクリプトに関する総合スレッドです。

全般
・荒しは無視しましょう。
・丁寧な姿勢を心掛けましょう。
・ネチケット(死語)を意識しましょう。

前スレ:
シェルスクリプト総合 その29
https://mevius.5ch.net/test/read.cgi/tech/1537540487/
2019/07/30(火) 22:00:29.38ID:TDafWW+v
>>425
ははーん。そういうことか。
Solaris Bシェルが持ってた拡張機能じゃなくてSolaris Bシェルに対する拡張機能だった訳ね。
Solarisの手引書を漁っても見付からない訳だ。
2019/07/30(火) 22:35:47.42ID:TDafWW+v
全然関係ないけど
$'\n'←こういうのって2020年あたりに発行されるPOSIXに組込まれるかもしれないらしいね。
そのページの下の方に書いてあった。
互換性とか大丈夫なのかな……?
2019/07/30(火) 22:45:31.33ID:TDafWW+v
参考: http://austingroupbugs.net/view.php?id=249
ていうかAustin GroupってThe Open Groupとは別ドメインなんだな。
サブグループだと思ってたわ。
2019/07/31(水) 12:01:53.51ID:6BPSvdm1
>>414
get-alias (gal)で、alias を表示できる。
多くのLinux コマンドのalias も、指定されている

gal | where-object {$_.Definition -match "remove-item"}
# Remove-Item のalias は、del, erase, rd, ri, rm, rmdir

gal | where-object {$_.Definition -match "copy-item"}
# Copy-Item のalias は、copy, cp, cpi

gal -name ls
# ls -> Get-ChildItem

gal -name echo
# echo -> Write-Output
2019/07/31(水) 16:37:25.52ID:kGX3Rh8Y
>>429
それ日本語が出てるの?
それとも日本語はあなたが付け足したの?
431デフォルトの名無しさん
垢版 |
2019/07/31(水) 22:49:22.63ID:FZL3ewwl
>>412
お釈迦様のアドバイス「犀の角のように独り歩め」も意味わからん…
2019/07/31(水) 23:18:58.96ID:kGX3Rh8Y
boshがビルドできずに諦めたw
2019/07/31(水) 23:25:31.28ID:8xUIRaAC
>>432
Debian 9で普通にmakeしたらできたけど?
正確にはDockerのbuildpack-depsだけど
2019/07/31(水) 23:39:26.64ID:8xUIRaAC
おや?最新版、2019-07-22版でビルド失敗した。

なんとなしにNetBSDでパッケージがあるのを見つけて使った2019-03-11版が運が良かったか
https://cdn.netbsd.org/pub/pkgsrc/current/pkgsrc/shells/bosh/README.html
2019/07/31(水) 23:57:18.53ID:8xUIRaAC
2019-06-13までは普通にビルドできるね
2019-07-15からビルドに失敗するようになってる
2019/08/01(木) 02:58:17.41ID:PmXIwIbo
>>435
情報ありがとう。古いので試してみるわ。
2019/08/01(木) 11:35:33.85ID:czAE5CE0
関数の中は、set -eで止めたいけど、関数の外では(後処理をするために)止めたくないって場合が辛いわ

例えばこんなコードがあって、falseで止まるようにしたいからset -eにするだろ?

foo() {
 set -e
 echo 1
 false
 echo 2
}

でも呼び出し側では必ず後処理をしたいから止めたくない。

set +e
foo
echo "後処理"

これだと止まってしまうから、foo &&: とかすると
今度は、fooの中でset -eの効果が無くなってしまう。何だこの仕様?

( foo ) とすると期待通りにfalseで止まるかつ後処理を実行できたが、
fooがサブシェルなので、fooの中で定義した変数にアクセスできない
困った
438デフォルトの名無しさん
垢版 |
2019/08/01(木) 12:20:40.41ID:aVYnxNEs
>>431
それは犀の角が一本だからという、特にひねりのない喩え。
2019/08/01(木) 12:25:28.77ID:iHxbPEOX
set -eはshellをexitするから当然の動作じゃない?
foo && : だと最終的なfooの戻り値を判定する必要があるからfalseで止まらずに最後まで行くんじゃないか

関数の中だけなら横着せずに
false || return
しろってことじゃないかな
2019/08/01(木) 13:07:42.24ID:lJwvTmEp
後処理だけなら、trap '後処理' ERR でやれば
根本的に -e の使い方が違うと思うけど
2019/08/01(木) 13:10:18.98ID:bR99qXsR
$ dash
$ trap : ERR
trap: ERR: bad trap
2019/08/01(木) 13:15:37.05ID:lJwvTmEp
EXIT でもいいぞ
2019/08/01(木) 13:17:58.23ID:bR99qXsR
どうやってEXITから終了せずに通常の流れに戻すの?
2019/08/01(木) 13:19:11.98ID:lJwvTmEp
なんやお前は
「後処理だけなら」って言ってるだろ
2019/08/01(木) 15:30:04.66ID:WaJjQk0q
SIGHUT とかのシグナル部分を書くとか?
2019/08/01(木) 20:47:35.88ID:SQRHjrcQ
func() {
return 123
}

if ! func; then
echo $?
fi

0って表示されるんだけど、どういうこと!?
2019/08/01(木) 21:31:03.39ID:2c4IvXw2
>>446
戻り値123を!しているから0になっただけでは
2019/08/01(木) 21:33:30.40ID:SQRHjrcQ
こう書けってことか?
面倒くさいな

if func; then
:
else
echo $?
fi
2019/08/01(木) 22:05:20.92ID:Ye1sT2dv
func || echo $? でいいんじゃね
2019/08/01(木) 22:10:56.38ID:SQRHjrcQ
実際にはecho $?以外にもすることがあるから
2019/08/01(木) 22:27:36.45ID:Ye1sT2dv
んじゃ、

func || { echo $?; ... ; }

とか。
2019/08/02(金) 02:34:53.77ID:hQ+yEyXN
Cじゃないから終了コードをそんな風に使わないほうが良い気がする…
あくまで「気がする」だけだけど
2019/08/02(金) 02:59:49.78ID:O3iYpUQI
値が 0 とそれ以外だけではなく、
それ以外にも、ある程度数値に意味があるのもあるからいいんじゃないのと思うけど
2019/08/02(金) 03:02:36.73ID:O3iYpUQI
ああ、そんな風 = 返り値が勝手に暗黙的に変わる変わらないってことかな?
だったらほぼ同意
2019/08/02(金) 03:40:21.45ID:hQ+yEyXN
>>453
あー。例えばあるコマンドで「ファイルが無い」ことを示すのに
exit 32が返ってくるとして
それに応じた最適なエラー処理をするってことかな?
2019/08/02(金) 03:54:22.19ID:O3iYpUQI
まあ元レスの人がどういう使い方をしたいのかわからんけど、そういう感じ
2019/08/02(金) 07:48:45.01ID:hQ+yEyXN
bcコマンドで階乗計算をしたくてコードを書いてるんだけど↓
n = 2
define f(n) {
f = 1
if (n == 0) { return(f) } /* 0! := 1 */
f = n * f(n - 1)
return(f)
}
"0! = "; f(0)
"1! = "; f(1)
"2! = "; f(2)
"5! = "; f(5)
多分これでいい筈なんだけどreturn式を二度使ってるのがダサく感じる…
もうちょっと賢い方法知らない?
2019/08/02(金) 07:49:38.54ID:hQ+yEyXN
ごめん一行目のn=2は無視って。
2019/08/02(金) 08:02:59.58ID:XJV5qmce
define f(n) {
if (n == 0) {
f = 1
} else {
f = n * f(n - 1)
}
return(f)
}

とか( n < 0 の場合、無限ループになるけど)
2019/08/02(金) 08:15:06.73ID:hQ+yEyXN
>>459
ありがとう。
でもelseって使えなくない? GNU bcだと使えるのかな?
http://pubs.opengroup.org/onlinepubs/9699919799/utilities/bc.html
2019/08/02(金) 08:42:59.37ID:dUmy9lW0
elseはGNU拡張
else使えないならこうするしかない

define f(n) {
if (n == 0) { f = 1 }
if (n != 0) { f = n * f(n - 1) }
return(f)
}
462デフォルトの名無しさん
垢版 |
2019/08/02(金) 09:23:07.90ID:7tJhBDcy
>>438
それ喩える意味あるぅ?
情報量低すぎるどころか混乱を招いて逆効果だわ。
「グーはチョキに勝つ。そう、斧が槍に強いように」とか言われてる気分。
2019/08/02(金) 11:27:07.42ID:hQ+yEyXN
世の中には例え話を持ち出さないと気が済まない人が一定数存在する。
464デフォルトの名無しさん
垢版 |
2019/08/02(金) 12:50:24.63ID:vUPSv33I
>>462
知らんけど昔の人が思い付いていいと思ったから書いたんだろう。
2019/08/02(金) 12:51:11.15ID:hQ+yEyXN
>>190 WindowsにJavaが入るかもって話あったの?そもそもそんな話すらなくね?
2019/08/02(金) 13:50:46.03ID:pa9nweBb
>>465
昔あったっしょ
Microsoft J++だったっけ?
JDirectとか言うCOMかActiveXコントロールかを直接呼び出せる機能拡張付きで、
それにSunがケチを付けて(確か)裁判沙汰になって、結局廃止になったやつ
TCKにも通らないだろうからJavaは名乗れないはずだけど
467デフォルトの名無しさん
垢版 |
2019/08/02(金) 13:54:51.56ID:xsQQm7uF
>>465
90年代後半にだな・・・
2019/08/02(金) 13:57:46.29ID:XJV5qmce
「マイクロソフトが Java に塩を混ぜた!」ってやつか
2019/08/02(金) 20:32:46.34ID:hQ+yEyXN
sedかなにかで↓
<td>
AAAA
</td>
<td>
BBBB
</td>
↑っていうデータのBBBを取り出したい。

残念なことにtdにIDやらなにやらが賦与されてないから手段としては
「1番目に表われた/<td>/<\/td>/は無視って2番目の/<td>/<\/td>/の中身を表示する」
っていうのになると思う。しかし方法が思い付かない……。
できればsed, awkあたりで処理できればいいなと思ってるんだけど,どなたか力を貸してほしい。

上のデータだけど,「実際はもっと複雑でtableが入れ子になってる」とかそういうことはないです。
2019/08/02(金) 20:38:11.21ID:cEuue6ob
なら5行目を取り出せばいいじゃん
2019/08/02(金) 20:40:10.25ID:2UnKye9C
/^<td>$/{n;/BBB/p}
2019/08/02(金) 20:44:47.38ID:O3iYpUQI
今までのレスからはそんな質問するはずがないとしか思えないんだけどw
<td>AAA
</td>
<td>
BBB</td>
なんぞリターンがあってもなくてもいいというhtml/xmlらしく、行がちゃんとしているわけではないとか?
2019/08/02(金) 21:06:45.26ID:dUmy9lW0
>>469
俺ならシェルスクリプト使わずにHTMLパーサに食わせるな
nodejsでcheerio使うとか楽な方法を選ぶね
2019/08/02(金) 21:06:52.97ID:XJV5qmce
GNU sed の -z オプションを使って

$ sed -rz 's:.*</td>\n?<td>\n?(.*)</td>.*:\1:' data.html
2019/08/02(金) 21:07:39.38ID:hQ+yEyXN
>>472
そうです。相手はHTMLなんで改行されてない場合が普通にあるんです……。
つくづくUnixツールとマークアップ言語は相性悪いなぁと思いますw
2019/08/02(金) 21:30:15.54ID:XJV5qmce
GNU grep ならこんな感じ

$ grep -Pzo '<td>\n?\K(.|\n)*?(?=\n?</td>)' x.xml | tr '\0' '\n' | sed -n 2p
2019/08/02(金) 21:35:20.07ID:hQ+yEyXN
>>476
すげぇ!
ありがとうございます!とりあえず脳死状態でコピペさせていただきます。
正規表現の勉強しないとなぁ……。
2019/08/02(金) 21:38:37.66ID:cEuue6ob
正直、CLIツール使って一発でやってしまおう!
なんて考えるから難しくなるんだよ。
一行一データになってないものは、
シェルスクリプトでやったほうが楽

#!/bin/sh
a=$(cat html.txt)
a=${a#*<td>}
a=${a#*<td>}
a=${a%%</td>*}
echo "$a"
2019/08/02(金) 21:38:54.44ID:+p+nzQa3
>>475
>を>\nにして\n\nを\nにすればいいだけじゃないの?
480デフォルトの名無しさん
垢版 |
2019/08/02(金) 21:59:02.93ID:T1FFAKuC
xmllint使えは禁句なの?
2019/08/02(金) 22:00:05.58ID:G/LyK8vk
Ruby なら、すべての改行を削除してから、最短マッチ

str = <<"EOT"
<td>
AAAA
</td>
<td>
BBBB
</td>
EOT

str.delete!( "\n" ) # すべての改行を削除する

re = /<td>(.*?)<\/td>/ # ? は最短マッチ

p results = str.scan( re ).flatten
# ["AAAA", "BBBB"]

p results[ 1 ]
# "BBBB"
2019/08/02(金) 22:47:11.19ID:hQ+yEyXN
>>480
残念ながらそのHTMLは整形形式じゃないのでマトモに解析できないんです。
483481
垢版 |
2019/08/02(金) 23:15:30.78ID:G/LyK8vk
Ruby で、nokogiri パーサーなら、

require 'nokogiri'

doc = Nokogiri::HTML( <<EOT.delete( "\n" ) ) # すべての改行を削除する
<td>
AAAA
</td>
<td>
BBBB
</td>
EOT


elements = doc.css( "td" )
p elements.first.content #=> "AAAA"
p elements[ 1 ].content #=> "BBBB"
2019/08/02(金) 23:29:54.36ID:pa9nweBb
>>476
\Kじゃなくて(?<=..._)で書いたほうが読みやすくね?とか思ったけど
PerlやPCREじゃlookbehindに可変長になるパターンは指定できないのか
JavaScriptだと通るんだよね....
2019/08/02(金) 23:34:34.72ID:cEuue6ob
Ruby遅すぎるんだよ

$ time ruby html.rb
"AAAA"
"BBBB"

real 0m0.079s
user 0m0.079s
sys 0m0.000s



$ time sh html.sh

BBBB

real 0m0.002s
user 0m0.002s
sys 0m0.000s
2019/08/02(金) 23:36:49.26ID:cEuue6ob
これも遅いな。やっぱりシェルスクリプトが一番か

$ time grep -Pzo '<td>\n?\K(.|\n)*?(?=\n?</td>)' x.xml | tr '\0' '\n' | sed -n 2p
BBBB

real 0m0.003s
user 0m0.004s
sys 0m0.003s
2019/08/02(金) 23:38:32.60ID:cEuue6ob
こうしたらさらに速くなったわw
シェルスクリプト最強伝説

#!/bin/sh
a="
<td>
AAAA
</td>
<td>
BBBB
</td>
"

a=${a#*<td>}
a=${a#*<td>}
a=${a%%</td>*}
echo "$a"

$ time sh html.sh

BBBB


real 0m0.001s
user 0m0.001s
sys 0m0.000s
2019/08/02(金) 23:46:41.69ID:dUmy9lW0
>>487
スクレイピングする時にそんなコード毎回書くわけ?
2019/08/02(金) 23:58:58.92ID:2UnKye9C
a#*
a%% あたりがシェルスクリプト独自の難読パーツだが
覚えたら高速なのか...
2019/08/03(土) 00:25:50.69ID:i7fqO3Sj
>>489
どっかの書籍(確かオライリー)に
数字を考えて#は数字の前に,%は数字の後に付ける。
という連想から
#及び##は前から削る,%及び%%は後から削ると覚えるといいと書いてあった。
2019/08/03(土) 00:33:21.53ID:dYT3TwZL
自分は
キーボードの左側: # -> prefix
キーボードの右側: % -> suffix
で、削るんだっったっけ?残すんだったっけ?
結局毎回調べるという体たらく
2019/08/03(土) 00:40:18.71ID:9AEx1UEu
>>490
thanks
493デフォルトの名無しさん
垢版 |
2019/08/03(土) 00:57:31.70ID:37D8ZUar
>>482
ブラウザでF12キーでコンソール開いて、
var q = (xml, query) => new DOMParser().parseFromString(`<xml>${xml}</xml>`, 'application/xml').querySelector(query).innerHTML.trim();

var text = q(`
<td>
AAAA
</td>
<td>
BBBB
</td>
`, 'td:nth-of-type(2)');
console.log(text); //=> BBBB

xmlとしてのパースだから、
q(`<chinko>AAAA</chinko><chinko>BBBB</chinko>`, 'chinko:nth-of-type(2)');
とかでも大丈夫。

一方htmlとしてもパースできるけど少なくともtableタグは補わなきゃならんね↓
var q = (html, query) => new DOMParser().parseFromString(html, 'text/html').querySelector(query).innerHTML.trim();

var text = q(`
<table>
<td>
AAAA
</td>
<td>
BBBB
</td>
</table>
`, 'td:nth-of-type(2)');
console.log(text); //=> BBBB
2019/08/03(土) 03:42:42.10ID:eOXqQaf9
>>490
> 数字を考えて#は数字の前に,
あー、ナンバーサインか

俺は、コメントだから頭につけるって覚えてたわ
%は同じく100%の%で後ろって覚えてたけど
2019/08/03(土) 04:43:13.91ID:i7fqO3Sj
>>494
俺含め日本人には#42みたいなのは馴染み薄いよね…
まあ「全く知らない概念」ではなかったから
とりあえず#は前,%は後,というように覚えられたけど。
コメントっていうのはいい案だと思う。
シェルスクリプトを書いている全員が把握できる概念だから。
2019/08/03(土) 05:33:16.75ID:20yQPXqo
ナンバナィン?

#はスーパーユーザで%はcshだな
2019/08/03(土) 06:07:39.94ID:l2kKbyZy
シェルスクリプトの#と%はなんとなく使えてるが正規表現の前後読みは未だに無理ポ
2019/08/03(土) 06:23:53.55ID:i7fqO3Sj
正規表現の割と新しめの拡張は
既存のメタ文字と被らないようになってるから類推しにくい記号になってしまってる場合が多い。
…まあ出典とかなくて俺の予想だけどw

最近だと「名前空間」的な概念が登場して\p{Kata}みたいな書き方が増えてきて助かる。
覚えるの簡単!
2019/08/03(土) 08:10:24.89ID:GWDLl7Iz
なんのこっちゃと思ったら.NETか
[:Katakana:]でいいんじゃないか。すでにあるからわかりやすいし
思惑でそうしてないんだろうけど
2019/08/03(土) 09:10:18.89ID:i7fqO3Sj
>>499
いや\p{Kata}っていう正規表現が使えるのはかなり広範な言語よ
少くともICUバインディングがあれば使える筈。
2019/08/03(土) 09:11:02.22ID:i7fqO3Sj
逆に.NETでUnicodeロケールの正規表現が使えるとは思いもよらなんだ
2019/08/03(土) 09:42:41.49ID:9AEx1UEu
...| perl -pe 's{" [^"]+ "}{ $& =~ s/ /-/gr }xeg'|...
awk でもできるかもしれないけどこの正規表現が便利
"text with blank space" の中だけ空白を-で詰め物するのに使っている

空白があると正常に動作しないコードの前パイプに挟む
2019/08/03(土) 10:30:59.00ID:i7fqO3Sj
>>502
なんかコマンドの引数の仕様とかを利用して
POSIXの範囲で実装できそう。
もちろんperlで十分だけど。

abc def "text with blacket" dee
に対して
abc def "text-with-blacket" dee
ってい出力を返す訳だから
for str in abc def "text-with-blacket" dee; do
printf '%s\n' "$str" | tr ' ' '-'
done | tr '\n' ' '
とか?
あ,駄目だこれだと"が戻ってこねーw
2019/08/03(土) 11:33:18.72ID:63RDVzrz
無理やり

echo 'abc def "text with blcket" dee' |
sed -E 's:^(.*)"([^"]*)"(.*)$:printf "%s\\"%s\\"%s\n" "\1" $(echo "\2"|tr " " "-") "\3":e'
2019/08/03(土) 11:35:32.45ID:l2kKbyZy
$ echo やまだヤマダ山田 | grep -oP "\p{Katakana}"




-o使うと改行されるのね
2019/08/03(土) 12:22:48.42ID:63RDVzrz
スペース区切りでよければ

$ echo やまだヤマダ山田 | grep -oP "\p{Katakana}" | xargs
ヤ マ ダ
2019/08/03(土) 13:09:38.57ID:H1MpioV8
>>485
何百ページもパースするの?
Ruby でも十分早いと思うけどなあ
2019/08/03(土) 13:55:12.22ID:dYT3TwZL
40秒で支度しな
509デフォルトの名無しさん
垢版 |
2019/08/04(日) 17:11:27.60ID:d0z5l48N
俺だったらperl使って全部読んで長い一行として扱って抜き出すか、または XML::Simple モジュール使って変数に展開してから取り出すかするかな。

つまり、シェルスクリプトは使わない。やってやれないことはないと思うが複雑怪奇なものになりそうなので。
510デフォルトの名無しさん
垢版 |
2019/08/04(日) 17:12:43.83ID:d0z5l48N
あ、リロード忘れて書いたら山盛りで他の書き込みが・・・

俺の書いたことは忘れてくれ。
511デフォルトの名無しさん
垢版 |
2019/08/04(日) 17:13:02.34ID:arZQ1GVT
【小沢が育てた刺客】 山本太郎「政権を仕留める」
http://lavender.5ch.net/test/read.cgi/giin/1564896780/l50
512デフォルトの名無しさん
垢版 |
2019/08/04(日) 18:10:11.11ID:d0z5l48N
丸くても刺客
2019/08/04(日) 18:11:50.20ID:M00OQnGm
40秒で刺客しな
514デフォルトの名無しさん
垢版 |
2019/08/04(日) 18:22:43.73ID:OC9PgLo7
PythonのBeautifulSoupだと、パーサーにCで書かれたlxmlを選べるようになってるんだが、
そういうの使えば、シェルの方が断然速いとはならないんじゃないかな?
PerlとかRubyにも似たようなのはあるでしょ。
2019/08/04(日) 18:40:40.05ID:zjBZp1dd
ディレクトリに、test01 〜 test99 ファイルがある時に、
test100, test101 と、ファイルを増やしていくと、

表示順が、test20, test21 などよりも、
test100, test101 の方が、先に来るようになった

これらを数字順で表示するには、どういうフィルターを作れば良いでしょう?

まあ、すべてのファイル名を、test001 など、3桁表示に変えれば、解決するけど
2019/08/04(日) 19:18:29.22ID:ApCAdEzq
>>515
プレフィクスが一緒なら
そのプレフィクスと0パディングを切り取ってsortに掛ければいいんじゃないかな。
で並び換えたものにプレフィクスと%0dを追加する。

ファイル名じゃなくてすまんが↓こんな感じ?
$ <<. sed 's/test0*//1' | sort -n | while read line; do printf 'test%02d\n' $line; done
test99
test100
test21
test01
test20
test101
.
517516
垢版 |
2019/08/04(日) 19:38:16.75ID:ApCAdEzq
改良。あとsort -nって0埋め関係ないんだな。
http://pubs.opengroup.org/onlinepubs/9699919799/utilities/sort.html#tag_20_119_04

ls -1 test* | sed 's/^test//' | sort -n | xargs -I @ printf 'test%02d\n' @
2019/08/04(日) 19:45:40.73ID:ZVJM9ExE
>>515
GNUのsortなら-Vオプションがあるけど...
ls | sort -V
あるいはtest[0-9]*のファイルだけなら
ls | sort -t t -k 3n
とか(汚いけど)
2019/08/04(日) 20:01:45.96ID:hlZDnb3L
>>515
ls -v
2019/08/04(日) 20:02:42.33ID:/i7K4ZYC
>>515
GNU coreutils の ls コマンドなら -v オプションで version sort してくれる

$ ls -v test*
$ man ls

-v natural sort of (version) numbers within text
2019/08/04(日) 20:05:19.04ID:KSih4AJE
となるとMacは切り捨てだな
2019/08/04(日) 20:06:51.77ID:ZVJM9ExE
おお、lsにも-vオプションあったっけ
523515
垢版 |
2019/08/04(日) 21:06:16.73ID:zjBZp1dd
>>518
GNUのsort、-V オプション
ls | sort -V

これは便利!
2019/08/04(日) 21:11:25.12ID:WhAPGaK9
sort --help には
-V, --version-sort 自然な (バージョン) 数字順でソートする

って書いてあるけどさ、これセマンティクスバージョニングでの
比較にちゃんとなってるの?正確な仕様がわからん
2019/08/04(日) 21:14:26.03ID:ApCAdEzq
なんにせよ可搬性ないからあまり使わんほうがいい
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況