CGIについての質問は板違いです。WEBプログラミング板でどうぞ。
CGIとPerlの区別がつかない人もWEBプログラミング板に行ってください。
(WEBプログラミング板: http://kohada.2ch.net/php/)
このスレでは(CGI以外の)純粋にPerlのみに関係する質問を取り扱っていこうと思います。
スレ違いの質問にはスルーか、速やかな誘導をお願いします。
荒らしはスルー推奨。
"The duct tape of the Internet" こと、Perlについての質問箱です。
"There's more than one way to do it" ということで、
Perlの奥深さについて皆で語り合い、追求してまいりましょう。
www.perl.org/get.html
Download Latest Stable Source (5.18.2)
▼前スレ
Perlについての質問箱 61箱目
http://toro.2ch.net/test/read.cgi/tech/1381561905/
Perlについての質問箱 62箱目
http://toro.2ch.net/test/read.cgi/tech/1385039352/
Perlについての質問箱 63箱目
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
2014/02/19(水) 23:36:23.29713デフォルトの名無しさん
2017/05/03(水) 02:40:51.60ID:0sDWrHda $ perl6 -v
This is perl6 version 2015.11 built on MoarVM version 2015.11
すいません、解決しました
This is perl6 version 2015.11 built on MoarVM version 2015.11
すいません、解決しました
714デフォルトの名無しさん
2017/05/11(木) 19:50:38.19ID:nIm7OIQv POD書いてる?
715デフォルトの名無しさん
2017/05/11(木) 23:25:04.61ID:nen5x9dT メモリリーク検出になに使ってる?
とりあえず昔からTest::LeakTrace使ってるんだけど
いまはもっと便利なものがあったりするのかな?
とりあえず昔からTest::LeakTrace使ってるんだけど
いまはもっと便利なものがあったりするのかな?
716デフォルトの名無しさん
2017/05/24(水) 13:05:14.66ID:9utV0RoM Perl/Qt は癖があるね、Perl/Qtとクラスを同時に使おうとするとなかなか大変。
717デフォルトの名無しさん
2017/05/28(日) 12:56:56.81ID:+Ey6Jlm8 テキストファイルを読み込むときに
// (例えばfile://...)
があると、そこから行末まで読み込めない現象が起きるんだけど
どうしたらちゃんと読み込める?
binmodeにしても解決しなかった
// (例えばfile://...)
があると、そこから行末まで読み込めない現象が起きるんだけど
どうしたらちゃんと読み込める?
binmodeにしても解決しなかった
718デフォルトの名無しさん
2017/05/28(日) 13:01:09.18ID:+Ey6Jlm8719デフォルトの名無しさん
2017/05/28(日) 14:02:42.07ID:0c9kwMSl そんな訳ない
720デフォルトの名無しさん
2017/05/28(日) 14:05:21.98ID:9RwfEHwH ファイルハンドルからダブルスラッシュが含まれる行を読み込もうとするとダブルスラッシュが行末と誤認されるという解釈でいいんですかね
721デフォルトの名無しさん
2017/05/28(日) 14:33:51.85ID:eFuC5yco 絶対になにかカンチガイしてるだろう。
単に出力のバッファリングで単に表示されてないだけとか。
もしくは自分で"//"以降を削除するような処理をしているとかだな。
正規表現の書き誤りがあやしい。
単に出力のバッファリングで単に表示されてないだけとか。
もしくは自分で"//"以降を削除するような処理をしているとかだな。
正規表現の書き誤りがあやしい。
722デフォルトの名無しさん
2017/05/28(日) 14:59:23.09ID:0c9kwMSl 実際に、>>717の方法で読ませればちゃんと読む筈
怪しい箇所を削っていって試せばいい
怪しい箇所を削っていって試せばいい
723デフォルトの名無しさん
2017/05/28(日) 15:01:31.81ID:/dM5Kslk >>717
再現コードを
再現コードを
724717
2017/05/28(日) 16:52:39.75ID:+Ey6Jlm8 カンチガイでした
別のところでCのコメント削除をしていて
そこで消えてました
テヘペロ
別のところでCのコメント削除をしていて
そこで消えてました
テヘペロ
725デフォルトの名無しさん
2017/05/28(日) 18:05:45.48ID:DFLy+ixu ま、そんなもんよ
いい経験したな
次に活かせよ
いい経験したな
次に活かせよ
726デフォルトの名無しさん
2017/05/28(日) 20:22:17.89ID:4xPNWoV3 C/C++のソースコードを読んで
コメント削除したソースコード
ifdefとかのプリプロセスしたソースコード
typedef, struct, unionとかを抽出した結果
を得たいんだけどどうするのがいいだろう
プリプロセスしたソースコードをcflowに渡すと
関数コールツリーを得られるから
それらを使ってCのソースコード理解に役立てたい
コメント削除したソースコード
ifdefとかのプリプロセスしたソースコード
typedef, struct, unionとかを抽出した結果
を得たいんだけどどうするのがいいだろう
プリプロセスしたソースコードをcflowに渡すと
関数コールツリーを得られるから
それらを使ってCのソースコード理解に役立てたい
727デフォルトの名無しさん
2017/05/28(日) 21:37:34.83ID:QPUrPhGM >>726
何が難しいのか、なんでそんなことをしたいのかよくわからん。
何が難しいのか、なんでそんなことをしたいのかよくわからん。
728デフォルトの名無しさん
2017/05/28(日) 22:39:53.18ID:H3cdg50W >>726
自前で作るって話からは外れるけど、Doxygenに突っ込むとかじゃダメなの?
自前で作るって話からは外れるけど、Doxygenに突っ込むとかじゃダメなの?
729デフォルトの名無しさん
2017/05/29(月) 06:06:36.99ID:iFMZQ+Zt >>727
Cのソースコード理解のため
難しいのは例えばif x>=10 && (defined(y) || z==1)とか
ifdef elif else endifとかの入れ子とか
を正しくパースしたりすること
structを抽出したあと
それらの参照関係も図示したい
Cのソースコード理解のため
難しいのは例えばif x>=10 && (defined(y) || z==1)とか
ifdef elif else endifとかの入れ子とか
を正しくパースしたりすること
structを抽出したあと
それらの参照関係も図示したい
730デフォルトの名無しさん
2017/05/29(月) 06:07:01.52ID:iFMZQ+Zt >>727
簡単なら作ってgitとかにあげてほしい
簡単なら作ってgitとかにあげてほしい
731デフォルトの名無しさん
2017/05/29(月) 06:09:33.49ID:iFMZQ+Zt732デフォルトの名無しさん
2017/05/29(月) 06:15:46.76ID:1pPkP4QE gcc -E じゃだめなのか。
cpp のソースコードを読んでみるのがいいと思うよ。
昔、LSI-C 86 のプリプロセッサのソースコード読んで勉強したなあ。
cpp のソースコードを読んでみるのがいいと思うよ。
昔、LSI-C 86 のプリプロセッサのソースコード読んで勉強したなあ。
733デフォルトの名無しさん
2017/05/29(月) 07:11:36.94ID:7MORbIbH >>726
cflowの中でプリプロセスするから事前にする必要はないと思うけど
cflowの中でプリプロセスするから事前にする必要はないと思うけど
734デフォルトの名無しさん
2017/05/29(月) 17:52:39.84ID:aFd0yPA1735デフォルトの名無しさん
2017/05/29(月) 18:14:45.54ID:aFd0yPA1 例えば
#define ERRLVL 5
#define WARLVL 3
とかなってるのをプリプロセスすると
数字に置き換わるので意味が判りにくくなる
だけど#ifdefとかはプリプロセスしないと
例えば32ビット版の関数や構造体と
64ビット版の関数や構造体が重複してしまう
#define ERRLVL 5
#define WARLVL 3
とかなってるのをプリプロセスすると
数字に置き換わるので意味が判りにくくなる
だけど#ifdefとかはプリプロセスしないと
例えば32ビット版の関数や構造体と
64ビット版の関数や構造体が重複してしまう
736デフォルトの名無しさん
2017/05/30(火) 04:54:25.56ID:Al54U2am CPAN に Text::CPP なんてのがあるよ。
そのままではご要望どおりじゃないと思うけど参考にはなるかも。
そのままではご要望どおりじゃないと思うけど参考にはなるかも。
737デフォルトの名無しさん
2017/05/30(火) 20:58:34.87ID:Al54U2am 言いたいことはよく解る。
とりあえず、プリプロセッサの通常の動作から変更したいのは
・C ソースの中のマクロ置換はしない
・#define ディレクティブは用済みになっていないのでそのまま出力する
といったところ?
もし Text::CPP の作者がそれを有意義だと思ってくれたら、
なんとかしてくれる可能性もなくはないかもしれないな。
連絡先は README に書いてあるよ。
とりあえず、プリプロセッサの通常の動作から変更したいのは
・C ソースの中のマクロ置換はしない
・#define ディレクティブは用済みになっていないのでそのまま出力する
といったところ?
もし Text::CPP の作者がそれを有意義だと思ってくれたら、
なんとかしてくれる可能性もなくはないかもしれないな。
連絡先は README に書いてあるよ。
738デフォルトの名無しさん
2017/05/30(火) 21:10:46.26ID:Al54U2am cpp をそのまま使うという方法もなくはないよ。
#define ディレクティブの前と C ソーステキストの前の行に
#line ディレクティブを入れる。
cpp の処理結果には #line ディレクティブがあるから
それを手がかりに元のファイルからコピーする。
この程度のことなら出来そうじゃない?
#define ディレクティブの前と C ソーステキストの前の行に
#line ディレクティブを入れる。
cpp の処理結果には #line ディレクティブがあるから
それを手がかりに元のファイルからコピーする。
この程度のことなら出来そうじゃない?
739726
2017/06/01(木) 00:33:15.15ID:mVcFCi6e 作ってみたけどバグがあるだろう
https://github.com/bran1219/mycpp
https://github.com/bran1219/mycpp
740デフォルトの名無しさん
2017/06/04(日) 17:04:48.43ID:JLuePf+9 あまり野暮なことはいいたくないけど、ファイルハンドルから行を読むんじゃなくて
トークンを読んだ方がシンプルに書けるんじゃないかな。そうすれば
while(( my $tokentype,my $str) = gettoken( $fh)){
if ( $tokentype == 'comment'){ case_comment;}
elsif ( $tokentype == 'string'){ case_string;}
みたいなやり方が出来る。気を悪くしないでほしい。本当にそう思ったんだ。
トークンを読んだ方がシンプルに書けるんじゃないかな。そうすれば
while(( my $tokentype,my $str) = gettoken( $fh)){
if ( $tokentype == 'comment'){ case_comment;}
elsif ( $tokentype == 'string'){ case_string;}
みたいなやり方が出来る。気を悪くしないでほしい。本当にそう思ったんだ。
741デフォルトの名無しさん
2017/06/05(月) 23:40:47.35ID:AlRALdx8 gettoken()を作ってread()で一文字ずつ読み込んでトークンを返すのは良さそうだけど
トークンタイプはその時の状態が判らないと判別できないと思う
//は普通の状態で現れたらコメント開始だけど
"の中だと文字列
/*の中だとコメント文字列
トークンタイプはその時の状態が判らないと判別できないと思う
//は普通の状態で現れたらコメント開始だけど
"の中だと文字列
/*の中だとコメント文字列
742デフォルトの名無しさん
2017/06/09(金) 13:39:22.36ID:jmjGKHXw tcpのIO::Socket使ってサーバーに対してconnectした後、closeせずに親プロセスは接続を維持したまま、
forkした子プロセスでサーバーから受信した大量の文字列をファイルに書くとかするには子プロセスが継承したソケットをどう破棄したらいいの?
現状では当然の事ながら親プロセスの受信待ちが完全に止まってしまって困ってます
forkした子プロセスでサーバーから受信した大量の文字列をファイルに書くとかするには子プロセスが継承したソケットをどう破棄したらいいの?
現状では当然の事ながら親プロセスの受信待ちが完全に止まってしまって困ってます
743デフォルトの名無しさん
2017/06/09(金) 14:33:09.33ID:1EhRpyQk なぜ子プロセスでコネクトしないの?
744デフォルトの名無しさん
2017/06/09(金) 14:41:19.37ID:jmjGKHXw >>743
客先のサーバーの仕様とやらで複数の接続(connect)に対応していない模様(爆)
客先のサーバーの仕様とやらで複数の接続(connect)に対応していない模様(爆)
745デフォルトの名無しさん
2017/06/09(金) 19:57:08.76ID:ipZEdn/U >>744
親プロセスの接続を切れば複数接続じゃなくなると思う
親プロセスの接続を切れば複数接続じゃなくなると思う
746742
2017/06/10(土) 02:10:59.82ID:6TQL4PKJ 解決しました
fork()してから普通に子プロセス側で$socket->close();すれば良かったのですね。
ありがとうございました
fork()してから普通に子プロセス側で$socket->close();すれば良かったのですね。
ありがとうございました
747デフォルトの名無しさん
2017/06/13(火) 00:27:54.86ID:5t+GNw1N >>667,675-676
なぜこうなるの?
なぜこうなるの?
748デフォルトの名無しさん
2017/06/13(火) 02:06:41.19ID:Z49xlslC ヒント:
print"Hello world!\n";
print "Hello world!\n";
print("Hello world!\n");
print ( "Hello world!\n" );
print"Hello world!\n";
print "Hello world!\n";
print("Hello world!\n");
print ( "Hello world!\n" );
749デフォルトの名無しさん
2017/06/13(火) 06:02:24.69ID:TrwiR2C4 1. print 文は実行が成功するとTrue(1)を返す
2. すべての引数を括弧で括るのでなければ、print というキーワードの 次に開き括弧を書いてはいけません
ってだけの話。
print print print (1+2)+(4+5)+6+7;
は、
print (1+2) を実行したあとに
print 1+(4+5)+6+7実行して、
その戻り値1をプリントしてるだけ。
2. すべての引数を括弧で括るのでなければ、print というキーワードの 次に開き括弧を書いてはいけません
ってだけの話。
print print print (1+2)+(4+5)+6+7;
は、
print (1+2) を実行したあとに
print 1+(4+5)+6+7実行して、
その戻り値1をプリントしてるだけ。
750デフォルトの名無しさん
2017/06/14(水) 00:26:46.99ID:J0vYxrWi751デフォルトの名無しさん
2017/06/14(水) 07:10:52.51ID:nXcqV3BV >>741
そんな面倒なことを考えなくてもいいように gettoken を書くんだよ。
普通は C の文字列定数の中でわざわざ // を認識しない。どんなやりかたを考えてるの?
興味があるなら flex とかやったみたらどうかな。
そんな面倒なことを考えなくてもいいように gettoken を書くんだよ。
普通は C の文字列定数の中でわざわざ // を認識しない。どんなやりかたを考えてるの?
興味があるなら flex とかやったみたらどうかな。
752デフォルトの名無しさん
2017/06/14(水) 08:00:33.67ID:XYhnRuER >>751
文字列定数の中か外かはどうやって判別するの?
文字列定数の中か外かはどうやって判別するの?
753デフォルトの名無しさん
2017/06/14(水) 23:53:09.01ID:nXcqV3BV ずいぶん前のことなのに反応があって嬉しいよ。
とりあえず、行継続もプリプロセッサディレクティブの処理もエラーチェックも無し、
コメントと文字列だけでいいなら flex ならこう書ける。
https://ideone.com/NbLVjc
本当は '"' みたいな文字定数も想定しなきゃまずいけどね。
もちろん、flex を使わなくてもできる。
yylex を手書きするなら、まず 1 バイト読んで
switch ( c){
case '"': read_string(); break;
case '/': read_comment(); break;
みたいにするのが伝統的な方法だったりする。
この方法では switch から出る前にトークンを完結させる。
コメントや文字列定数の中と、それ以外の部分で文法が違うから
別の処理になっていると理解してほしい。
こうしなければならないわけではなく、テーブル駆動とかステートマシンが好みならそうすればいい。
重要なのは、yylex を 1 回呼べばトークンが 1 個完結しているということ。
もちろん Perl でも同じやり方はできる。できるけど…… Perl ですよ?
助けてくれるモジュールがあるんだから使ってみない? Parse::Lex とか。
flex をかじっておけば理解しやすいと思うよ。
とりあえず、行継続もプリプロセッサディレクティブの処理もエラーチェックも無し、
コメントと文字列だけでいいなら flex ならこう書ける。
https://ideone.com/NbLVjc
本当は '"' みたいな文字定数も想定しなきゃまずいけどね。
もちろん、flex を使わなくてもできる。
yylex を手書きするなら、まず 1 バイト読んで
switch ( c){
case '"': read_string(); break;
case '/': read_comment(); break;
みたいにするのが伝統的な方法だったりする。
この方法では switch から出る前にトークンを完結させる。
コメントや文字列定数の中と、それ以外の部分で文法が違うから
別の処理になっていると理解してほしい。
こうしなければならないわけではなく、テーブル駆動とかステートマシンが好みならそうすればいい。
重要なのは、yylex を 1 回呼べばトークンが 1 個完結しているということ。
もちろん Perl でも同じやり方はできる。できるけど…… Perl ですよ?
助けてくれるモジュールがあるんだから使ってみない? Parse::Lex とか。
flex をかじっておけば理解しやすいと思うよ。
754デフォルトの名無しさん
2017/06/16(金) 07:59:43.13ID:ULLUKZU9 >>753
それはcase文の文字で状態遷移してるのと等価
"があったら文字列の中の状態
/があったらコメント開始の1文字目の状態
モジュールを使ったのがネットにあったから使ってみたけど
期待と違ったから自作した
それはcase文の文字で状態遷移してるのと等価
"があったら文字列の中の状態
/があったらコメント開始の1文字目の状態
モジュールを使ったのがネットにあったから使ってみたけど
期待と違ったから自作した
755デフォルトの名無しさん
2017/06/16(金) 08:02:46.40ID:ULLUKZU9756デフォルトの名無しさん
2017/06/23(金) 23:36:24.65ID:jQG6z3fn ネストしたブロックを正規表現でとりたくてperlreにある再帰パターンというのつかおうとしているですが(?>[^()]+)の部分うまくかきかえられません。
loop〜end loopの形にしたいのですが、 (?!)の使い方がわるいのかヒットしないorz
loop〜end loopの形にしたいのですが、 (?!)の使い方がわるいのかヒットしないorz
757デフォルトの名無しさん
2017/06/26(月) 23:50:27.94ID:zIACp4Pg (?>¥b(?!end loop|loop)で行けました。
ヒットしなかったのは再帰始まりのloopと干渉していたらしく、始まりをちゃんと書いたら動きました。
ヒットしなかったのは再帰始まりのloopと干渉していたらしく、始まりをちゃんと書いたら動きました。
758デフォルトの名無しさん
2017/06/28(水) 23:50:10.85ID:eZnf2YJC FW使わずにpsgi/slackを使おうとしてて、モジュールの名前と言うか場所に悩んでます(´・ω・`)
pathがperl -I /hoge/lib/として、
/hoge/lib/Controller.pmみたいのを置きたいけど名前被りが嫌なので避けるための手法として
/hoge/lib/myController.pmとか
/hoge/lib/MyApp/Controller.pmとかあると思うんですが
perlでこういう場合の命名規則?というかお約束みたいな名前ってあるんでしょうか。
/hoge/lib/作ってるサイトのドメイン/Controller.pm
みたいにしようと思ったけど、
use 作ってるサイトのドメイン::Controller.pm
こんなの使いまわし効かなさすぎて嫌すぎる
pathがperl -I /hoge/lib/として、
/hoge/lib/Controller.pmみたいのを置きたいけど名前被りが嫌なので避けるための手法として
/hoge/lib/myController.pmとか
/hoge/lib/MyApp/Controller.pmとかあると思うんですが
perlでこういう場合の命名規則?というかお約束みたいな名前ってあるんでしょうか。
/hoge/lib/作ってるサイトのドメイン/Controller.pm
みたいにしようと思ったけど、
use 作ってるサイトのドメイン::Controller.pm
こんなの使いまわし効かなさすぎて嫌すぎる
759デフォルトの名無しさん
2017/06/29(木) 06:52:20.07ID:jqMU9B7T お約束はない。
>こんなの使いまわし効かなさすぎて嫌すぎる
ん?
スクリプト内で動的に変更したいとか、そこらへん?
じゃなきゃ普通に use XXXX::Controller で作っちゃうけど?
あとは、物理的にパス切らない。くらいだよね?
$ cat Hoge.pm
package Hoge::Foo;
sub hoge{ "hoge" }
1 ;
$ perl -MHoge -le 'print Hoge::Foo::hoge'
myController.pm 一個作って、中で切り分けちゃえば?
>こんなの使いまわし効かなさすぎて嫌すぎる
ん?
スクリプト内で動的に変更したいとか、そこらへん?
じゃなきゃ普通に use XXXX::Controller で作っちゃうけど?
あとは、物理的にパス切らない。くらいだよね?
$ cat Hoge.pm
package Hoge::Foo;
sub hoge{ "hoge" }
1 ;
$ perl -MHoge -le 'print Hoge::Foo::hoge'
myController.pm 一個作って、中で切り分けちゃえば?
760デフォルトの名無しさん
2017/06/29(木) 15:18:22.72ID:/7f1HAmp どもです。
URLで言うexample.comみたいな不可侵領域?的なのが無いのかなぁと思った感じでした。
URLで言うexample.comみたいな不可侵領域?的なのが無いのかなぁと思った感じでした。
761デフォルトの名無しさん
2017/06/29(木) 17:00:57.00ID:sULhhpBu762デフォルトの名無しさん
2017/06/29(木) 17:25:38.71ID:/7f1HAmp >>761
> もしプライベートな内部やプロジェクト固有の用途のために開発中のモジュールが 決して公開されることがないなら、
> 将来の公開モジュールと名前が 衝突しないことを確実にしてください。
> これは、予約済みの Local::* カテゴリを使うか、 Foo_Corp::* のように 名前にした戦を含めることで行えます。
これだあああ
戦ってのが謎ですが、Localディレクトリに入れることにします。
ありがとうございます!
> もしプライベートな内部やプロジェクト固有の用途のために開発中のモジュールが 決して公開されることがないなら、
> 将来の公開モジュールと名前が 衝突しないことを確実にしてください。
> これは、予約済みの Local::* カテゴリを使うか、 Foo_Corp::* のように 名前にした戦を含めることで行えます。
これだあああ
戦ってのが謎ですが、Localディレクトリに入れることにします。
ありがとうございます!
763デフォルトの名無しさん
2017/06/29(木) 17:51:43.29ID:MlIjnXqh たぶん「した戦」→「下線」アンダーラインのことかと
> Foo_Corp::* のように 名前に下線を含めることで
> Foo_Corp::* のように 名前に下線を含めることで
764デフォルトの名無しさん
2017/06/29(木) 18:03:16.93ID:/7f1HAmp なるほど…
ちゃんと訳した上で漢字を変な読み方した状態でのタイポとはw
ちゃんと訳した上で漢字を変な読み方した状態でのタイポとはw
765デフォルトの名無しさん
2017/06/30(金) 20:59:30.86ID:O3ckt/Q4 今とあるスクリプトを見たら
1 while(s/[\012\015]$//);
こんなん書いてあったんだけど、
たぶん改行とおぼしきものは全部消すってことだと思うんだけど、
いらんもんまで消しすぎたりしてない?
1 while(s/[\012\015]$//);
こんなん書いてあったんだけど、
たぶん改行とおぼしきものは全部消すってことだと思うんだけど、
いらんもんまで消しすぎたりしてない?
766デフォルトの名無しさん
2017/06/30(金) 21:30:32.10ID:nK8Rv+fa スカラー末の改行(の連続)を外す。
スカラー内の改行は外さない。
作者の意図通りに、余分なものは消さないと思うよ。
普通に、s/[¥012¥015]$//g ; すりゃいいと思うけど、、、
スカラー内の改行は外さない。
作者の意図通りに、余分なものは消さないと思うよ。
普通に、s/[¥012¥015]$//g ; すりゃいいと思うけど、、、
767デフォルトの名無しさん
2017/06/30(金) 23:49:28.02ID:5o89YkXB スカラー?
768デフォルトの名無しさん
2017/07/01(土) 06:06:23.31ID:756r6lLe whileとgは同じじゃない
769デフォルトの名無しさん
2017/07/01(土) 06:27:43.88ID:756r6lLe 文字の末尾が012か015だったら消すんじゃない?
文字コードもわからないけど
文字コードもわからないけど
770デフォルトの名無しさん
2017/07/01(土) 06:43:42.49ID:LXXRZ/Ka 動作は >>769 の通りだと思うけど
1 while が意味不明だな
1 while が意味不明だな
771デフォルトの名無しさん
2017/07/01(土) 06:50:18.42ID:756r6lLe while 1 はマニュアルにも記載されてる基本的な手法
条件だけで実行が完了する
条件だけで実行が完了する
772デフォルトの名無しさん
2017/07/01(土) 09:11:09.64ID:vTsOeFgm もっとくやしく
773デフォルトの名無しさん
2017/07/01(土) 09:24:13.31ID:B+Q6GXxH 1は無視していいよ
774デフォルトの名無しさん
2017/07/01(土) 10:05:39.83ID:756r6lLe 勉強し始めて1日で覚えるようなことを全然分からんようなやつが回答者ぶってるのかよ
775デフォルトの名無しさん
2017/07/01(土) 10:10:49.16ID:756r6lLe とりあえず一通り調べたけど、末尾に改行を使う文字コードはなかったから、
1 while(s/[\012\015]$//);
これは本当に改行を削除したいならあらゆる方法の中で最善だと思われる
本当にかたっぱしから消したいのなら、だけど…
1 while(s/[\012\015]$//);
これは本当に改行を削除したいならあらゆる方法の中で最善だと思われる
本当にかたっぱしから消したいのなら、だけど…
776デフォルトの名無しさん
2017/07/01(土) 10:11:51.33ID:756r6lLe と言うより $ が自動でその判定してるから、関係ないものは消えないはずなんだよね
777デフォルトの名無しさん
2017/07/01(土) 11:23:51.39ID:EnayukTL 取り敢えず、ベンチマーク。
$ cat bench.pl
#!/usr/bin/perl
use Benchmark qw( cmpthese timethese ) ;
my $f = +( "42¥r¥n" x 1000 ) . +( "¥r¥n" x 10000 ) ;
sub _gm { my $f2 = $f ; $f2 =~ s/[¥012¥015]$//gm ; }
sub _while { my $f2 = $f ; 1 while $f2 =~ s/[¥012¥015]$// ; }
cmpthese(timethese (undef, {
while => '_while',
gm => '_gm',
})) ;
$ perl bench.pl
Benchmark: running gm, while for at least 3 CPU seconds...
gm: 3 wallclock secs ( 3.36 usr + 0.01 sys = 3.37 CPU) @ 356.68/s (n=1202)
while: 3 wallclock secs ( 3.06 usr + 0.00 sys = 3.06 CPU) @ 152.94/s (n=468)
Rate while gm
while 153/s -- -57%
gm 357/s 133% --
$ cat bench.pl
#!/usr/bin/perl
use Benchmark qw( cmpthese timethese ) ;
my $f = +( "42¥r¥n" x 1000 ) . +( "¥r¥n" x 10000 ) ;
sub _gm { my $f2 = $f ; $f2 =~ s/[¥012¥015]$//gm ; }
sub _while { my $f2 = $f ; 1 while $f2 =~ s/[¥012¥015]$// ; }
cmpthese(timethese (undef, {
while => '_while',
gm => '_gm',
})) ;
$ perl bench.pl
Benchmark: running gm, while for at least 3 CPU seconds...
gm: 3 wallclock secs ( 3.36 usr + 0.01 sys = 3.37 CPU) @ 356.68/s (n=1202)
while: 3 wallclock secs ( 3.06 usr + 0.00 sys = 3.06 CPU) @ 152.94/s (n=468)
Rate while gm
while 153/s -- -57%
gm 357/s 133% --
778デフォルトの名無しさん
2017/07/01(土) 11:26:08.99ID:EnayukTL あ、単純に変数最後の CRLF 削りたいだけなら、比べ物にならん程
chomp の方が早い。
local $/ = “¥r¥n” ;
chomp $_ ;
chomp の方が早い。
local $/ = “¥r¥n” ;
chomp $_ ;
779デフォルトの名無しさん
2017/07/01(土) 12:14:31.52ID:B+Q6GXxH ActivePerlとCygwinの両方で動くようにしようと思うと、chomp使えないんだよな
780デフォルトの名無しさん
2017/07/01(土) 12:31:21.77ID:EnayukTL ん?
どっちが悪いか知らんが、
local $/ = “¥012¥015” ;
も効かんの?
どっちが悪いか知らんが、
local $/ = “¥012¥015” ;
も効かんの?
781デフォルトの名無しさん
2017/07/01(土) 12:36:32.24ID:756r6lLe \rだの\nだの使ってることに神経を疑っちまうぜ
と言うかutf8にさえ文字とみなされない文字を使ってる時点で…
ところで以下の3つは全部挙動が違いので並列にベンチとっても無意味
chomp;
s/[\012\015]$//gm;
1 while(s/[\012\015]$//);
特に真ん中のは色々とひどいことになると予想した
と言うかutf8にさえ文字とみなされない文字を使ってる時点で…
ところで以下の3つは全部挙動が違いので並列にベンチとっても無意味
chomp;
s/[\012\015]$//gm;
1 while(s/[\012\015]$//);
特に真ん中のは色々とひどいことになると予想した
782デフォルトの名無しさん
2017/07/01(土) 12:40:25.72ID:756r6lLe >>780
I/Oと言うのはその名の通りIとOがあってだな
I/Oと言うのはその名の通りIとOがあってだな
783デフォルトの名無しさん
2017/07/01(土) 12:48:39.37ID:EnayukTL >>781
ご指摘の通り俺が間違ってたわ。
chomp が違うのは同意
#!/usr/bin/perl
use Benchmark qw( cmpthese timethese ) ;
my $f = +( "42¥012¥015" x 1000 ) . +( “¥012¥015" x 10000 ) ;
sub _gms { my $f2 = $f ; $f2 =~ s/[¥012¥015]$//gms ; }
sub _while { my $f2 = $f ; 1 while $f2 =~ s/[¥012¥015]$// ; }
cmpthese(timethese (undef, {
while => '_while',
gms => '_gms',
})) ;
Benchmark: running gms, while for at least 3 CPU seconds...
gms: 4 wallclock secs ( 3.24 usr + 0.03 sys = 3.27 CPU) @ 391.13/s (n=1279)
while: 3 wallclock secs ( 3.01 usr + 0.03 sys = 3.04 CPU) @ 155.26/s (n=472)
Rate while gms
while 155/s -- -60%
gms 391/s 152% --
ご指摘の通り俺が間違ってたわ。
chomp が違うのは同意
#!/usr/bin/perl
use Benchmark qw( cmpthese timethese ) ;
my $f = +( "42¥012¥015" x 1000 ) . +( “¥012¥015" x 10000 ) ;
sub _gms { my $f2 = $f ; $f2 =~ s/[¥012¥015]$//gms ; }
sub _while { my $f2 = $f ; 1 while $f2 =~ s/[¥012¥015]$// ; }
cmpthese(timethese (undef, {
while => '_while',
gms => '_gms',
})) ;
Benchmark: running gms, while for at least 3 CPU seconds...
gms: 4 wallclock secs ( 3.24 usr + 0.03 sys = 3.27 CPU) @ 391.13/s (n=1279)
while: 3 wallclock secs ( 3.01 usr + 0.03 sys = 3.04 CPU) @ 155.26/s (n=472)
Rate while gms
while 155/s -- -60%
gms 391/s 152% --
784デフォルトの名無しさん
2017/07/01(土) 12:51:34.83ID:EnayukTL >>783 は上手く動いてねーw
すまん。全面的の俺のレスは脳内から消してくれ。
すまん。全面的の俺のレスは脳内から消してくれ。
785デフォルトの名無しさん
2017/07/01(土) 13:05:38.92ID:EnayukTL786デフォルトの名無しさん
2017/07/01(土) 15:21:02.94ID:iaxNT7Vw しかしなんで8進数?
これが普通なの?
これが普通なの?
787デフォルトの名無しさん
2017/07/01(土) 20:55:02.68ID:LXXRZ/Ka うーん いくら考えても 1 while() と書いてる意味がわからん
gオプションついてないから while の意味ないし
結果知りたいなら s/// の値を直で調べりゃ済む話だし
何故なんだ 誰か教えてください
gオプションついてないから while の意味ないし
結果知りたいなら s/// の値を直で調べりゃ済む話だし
何故なんだ 誰か教えてください
788デフォルトの名無しさん
2017/07/02(日) 02:22:16.04ID:ucaUnn+J 量指定子の存在しない世界線なのか。
#!/usr/bin/perl -w
use strict;
sub hd { print '[', join(' ', map uc unpack('H2', $_), split //, $_[0]), "]\n" }
my($lf, $cr, $n) = ("\012", "\015", "\n");
my $str = "$n$cr$lf$lf${cr}1${cr}2${lf}3$cr${lf}4${n}5$n$cr$lf$lf$cr$n";
$_ = $str; 1 while s/[\012\015]$//; hd($_);
($_ = $str) =~ s/[\012\015]$//g; hd($_);
($_ = $str) =~ s/[\012\015]+$//; hd($_);
__END__
なお改行が \015 でも \012 でもそれらの組み合わせでもない環境があるので、
$ と \Z と \z の意味するところは元のコードが使われていた環境に依存する。
http://perldoc.jp/docs/perl/perlport.pod#Newlines
#!/usr/bin/perl -w
use strict;
sub hd { print '[', join(' ', map uc unpack('H2', $_), split //, $_[0]), "]\n" }
my($lf, $cr, $n) = ("\012", "\015", "\n");
my $str = "$n$cr$lf$lf${cr}1${cr}2${lf}3$cr${lf}4${n}5$n$cr$lf$lf$cr$n";
$_ = $str; 1 while s/[\012\015]$//; hd($_);
($_ = $str) =~ s/[\012\015]$//g; hd($_);
($_ = $str) =~ s/[\012\015]+$//; hd($_);
__END__
なお改行が \015 でも \012 でもそれらの組み合わせでもない環境があるので、
$ と \Z と \z の意味するところは元のコードが使われていた環境に依存する。
http://perldoc.jp/docs/perl/perlport.pod#Newlines
789デフォルトの名無しさん
2017/07/02(日) 08:10:30.13ID:cmIXSukt ありがとう すごくよくわかった
1 whileの挙動をなにか勘違いしていたみたい
そしてベンチマーク取ってみたら
1 while s/[\012\015]$//; よりも while(s/[\012\015]$//){} の方が微妙に速かった
(すごく微妙なんだが 毎回1を評価しないでいい分の差??)
そして s/[\012\015]+$//; は1桁近く遅かった そうだったんだ…
1 whileの挙動をなにか勘違いしていたみたい
そしてベンチマーク取ってみたら
1 while s/[\012\015]$//; よりも while(s/[\012\015]$//){} の方が微妙に速かった
(すごく微妙なんだが 毎回1を評価しないでいい分の差??)
そして s/[\012\015]+$//; は1桁近く遅かった そうだったんだ…
790デフォルトの名無しさん
2017/07/02(日) 12:35:43.14ID:9IiniyIy オレ速度はあまり気にしないから、いつも素直に s/(?:¥r?¥n)+$//; の感じだな。
¥b入れた方がいいのかもしれないけれど入れたことはない。
$とって、gつければ、改行全部きえるはずだよ。
(行単位に分離されてそうだけど。。。)
¥b入れた方がいいのかもしれないけれど入れたことはない。
$とって、gつければ、改行全部きえるはずだよ。
(行単位に分離されてそうだけど。。。)
791デフォルトの名無しさん
2017/07/02(日) 14:53:25.87ID:ucaUnn+J >>789
一体どんな計り方をしたんだ。
http://perldoc.jp/docs/perl/perlperf.pod
http://perldoc.jp/docs/perl/perlcompile.pod#The32Decompiling32Back32End
#!/usr/bin/perl -w
use strict;
use Benchmark qw(cmpthese);
my($lf, $cr, $n) = ("\012", "\015", "\n");
for my $str ("$n$cr$lf$lf${cr}1${cr}2${lf}3$cr${lf}4${n}5$n$cr$lf$lf$cr$n", "abc$n", 'abc') {
cmpthese(-5, {
ws => sub { $_ = $str; 1 while s/[\012\015]$//; 1 },
wb => sub { $_ = $str; while (s/[\012\015]$//) {} 1 },
qu => sub { $_ = $str; s/[\012\015]+$//; 1 },
});
print "\n";
}
__END__
これぐらいシンプルな正規表現なら
エンジン内でのバックトラック >> 文自体の反復 >= ループ構造
文字列内に [\012\015] にマッチする文字があればあるほど qu の方が速くなる。
一体どんな計り方をしたんだ。
http://perldoc.jp/docs/perl/perlperf.pod
http://perldoc.jp/docs/perl/perlcompile.pod#The32Decompiling32Back32End
#!/usr/bin/perl -w
use strict;
use Benchmark qw(cmpthese);
my($lf, $cr, $n) = ("\012", "\015", "\n");
for my $str ("$n$cr$lf$lf${cr}1${cr}2${lf}3$cr${lf}4${n}5$n$cr$lf$lf$cr$n", "abc$n", 'abc') {
cmpthese(-5, {
ws => sub { $_ = $str; 1 while s/[\012\015]$//; 1 },
wb => sub { $_ = $str; while (s/[\012\015]$//) {} 1 },
qu => sub { $_ = $str; s/[\012\015]+$//; 1 },
});
print "\n";
}
__END__
これぐらいシンプルな正規表現なら
エンジン内でのバックトラック >> 文自体の反復 >= ループ構造
文字列内に [\012\015] にマッチする文字があればあるほど qu の方が速くなる。
792デフォルトの名無しさん
2017/07/02(日) 17:06:13.22ID:cmIXSukt こんな計り方↓
#!/usr/bin/perl
use strict;
use warnings;
use Benchmark qw/:all/;
my ($lf, $cr, $n) = ("\012", "\015", "\n");
my $str = "$n$cr$lf$lf${cr}1${cr}2${lf}3$cr${lf}4${n}5$n$cr$lf$lf$cr$n" x 100;
cmpthese -5, {
'1while' => sub {$_ = $str; 1 while s/[\012\015]$//;},
'1while_g' => sub {$_ = $str; 1 while s/[\012\015]$//g;},
quantifier => sub {$_ = $str; s/[\012\015]+$//;},
while_g => sub {$_ = $str; while (s/[\012\015]$//g){};},
while => sub {$_ = $str; while (s/[\012\015]$//){};},
};
__END__
同じwhileでもgオプションつけると微妙に速くなる
面白い
#!/usr/bin/perl
use strict;
use warnings;
use Benchmark qw/:all/;
my ($lf, $cr, $n) = ("\012", "\015", "\n");
my $str = "$n$cr$lf$lf${cr}1${cr}2${lf}3$cr${lf}4${n}5$n$cr$lf$lf$cr$n" x 100;
cmpthese -5, {
'1while' => sub {$_ = $str; 1 while s/[\012\015]$//;},
'1while_g' => sub {$_ = $str; 1 while s/[\012\015]$//g;},
quantifier => sub {$_ = $str; s/[\012\015]+$//;},
while_g => sub {$_ = $str; while (s/[\012\015]$//g){};},
while => sub {$_ = $str; while (s/[\012\015]$//){};},
};
__END__
同じwhileでもgオプションつけると微妙に速くなる
面白い
793デフォルトの名無しさん
2017/07/03(月) 04:18:38.68ID:7bJtUMTI >>792
自分の感覚と真逆の結果なんで -Mre=debug して調べたら、 [\012\015]$ だと
固定長だからエンジンが動作を最適化して最初から末尾しかみないんだな。
だから文字列自体が長くなると逆転が起こると。勉強になったよ。
#!/usr/bin/perl -w
use strict;
use Benchmark qw(cmpthese);
my $n = "\015\012";
my $sa = $n x 500; # 全文字にマッチ
my $sf = ($n x 250) . ('a' x 500); # + の場合前半に長くマッチした上で失敗する
my $sl = ('a' x 500) . ($n x 250); # 後半に長くマッチ
my $sn = 'a' x 1000; # マッチしない
my $su = ('a' x 998) . $n; # 末尾のみ
cmpthese(-5, {
wa => sub { $_ = $sa; 1 while s/[\012\015]$//; 1 },
wf => sub { $_ = $sf; 1 while s/[\012\015]$//; 1 },
wl => sub { $_ = $sl; 1 while s/[\012\015]$//; 1 },
wn => sub { $_ = $sn; 1 while s/[\012\015]$//; 1 },
wu => sub { $_ = $su; 1 while s/[\012\015]$//; 1 },
qa => sub { $_ = $sa; s/[\012\015]+$//; 1 },
qf => sub { $_ = $sf; s/[\012\015]+$//; 1 },
ql => sub { $_ = $sl; s/[\012\015]+$//; 1 },
qn => sub { $_ = $sn; s/[\012\015]+$//; 1 },
qu => sub { $_ = $su; s/[\012\015]+$//; 1 },
});
__END__
自分の感覚と真逆の結果なんで -Mre=debug して調べたら、 [\012\015]$ だと
固定長だからエンジンが動作を最適化して最初から末尾しかみないんだな。
だから文字列自体が長くなると逆転が起こると。勉強になったよ。
#!/usr/bin/perl -w
use strict;
use Benchmark qw(cmpthese);
my $n = "\015\012";
my $sa = $n x 500; # 全文字にマッチ
my $sf = ($n x 250) . ('a' x 500); # + の場合前半に長くマッチした上で失敗する
my $sl = ('a' x 500) . ($n x 250); # 後半に長くマッチ
my $sn = 'a' x 1000; # マッチしない
my $su = ('a' x 998) . $n; # 末尾のみ
cmpthese(-5, {
wa => sub { $_ = $sa; 1 while s/[\012\015]$//; 1 },
wf => sub { $_ = $sf; 1 while s/[\012\015]$//; 1 },
wl => sub { $_ = $sl; 1 while s/[\012\015]$//; 1 },
wn => sub { $_ = $sn; 1 while s/[\012\015]$//; 1 },
wu => sub { $_ = $su; 1 while s/[\012\015]$//; 1 },
qa => sub { $_ = $sa; s/[\012\015]+$//; 1 },
qf => sub { $_ = $sf; s/[\012\015]+$//; 1 },
ql => sub { $_ = $sl; s/[\012\015]+$//; 1 },
qn => sub { $_ = $sn; s/[\012\015]+$//; 1 },
qu => sub { $_ = $su; s/[\012\015]+$//; 1 },
});
__END__
794デフォルトの名無しさん
2017/07/03(月) 21:35:51.52ID:88Z7s+4Q795デフォルトの名無しさん
2017/08/15(火) 19:10:26.36ID:mGHj5vlw Perlに向いてるIDE教えて
デバッグ機能とかはいらない
補完と文法チェックとオートインデントが欲しい
デバッグ機能とかはいらない
補完と文法チェックとオートインデントが欲しい
796デフォルトの名無しさん
2017/08/16(水) 00:53:07.53ID:83B6OrrB 一番要るのはCPANとの連携機能だろ
797デフォルトの名無しさん
2017/08/17(木) 08:11:08.69ID:3rgoYIbT CPANとの連携機能はどっちでもいい
みんなメモ帳レベルのテキストエディタで書いてるの?
みんなメモ帳レベルのテキストエディタで書いてるの?
798デフォルトの名無しさん
2017/08/17(木) 08:48:00.96ID:ewlyrxLm IDEといいつつエディタでいいのか?
799デフォルトの名無しさん
2017/08/17(木) 21:40:11.78ID:DvPmzIRV vscode
800デフォルトの名無しさん
2017/08/17(木) 22:05:58.41ID:3rgoYIbT どこまでがエディタでどこまでがIDEなのか分からないが、それなりの機能は欲しい
自作関数とかも補完して欲しいしなあ
サンクス
vscode調べてみる
自作関数とかも補完して欲しいしなあ
サンクス
vscode調べてみる
801デフォルトの名無しさん
2017/08/26(土) 14:13:33.64ID:zbaxfQ1B802デフォルトの名無しさん
2017/08/27(日) 20:38:24.57ID:SUXQdIaA Perl6?
803デフォルトの名無しさん
2017/08/27(日) 21:17:36.95ID:l5ljwsJk 6は別物らしいね
804デフォルトの名無しさん
2017/08/27(日) 22:40:07.20ID:eg2XZFIG pythonもVBもバージョン上がると別物になる
そして大抵古い方が使いやすい
そして大抵古い方が使いやすい
805デフォルトの名無しさん
2017/08/27(日) 22:55:26.24ID:l5ljwsJk pythonはそろそろLinuxのデフォルトが3になりそうだけど
Perlはそんな気配全く無いよねw
Perlはそんな気配全く無いよねw
806デフォルトの名無しさん
2017/08/27(日) 23:11:43.20ID:QvkIPToQ システム付属のスクリプト言語っていう立ち位置がかつてのPerlからPythonに変わったからなあ
807デフォルトの名無しさん
2017/08/27(日) 23:14:14.93ID:eg2XZFIG 過去の資産が多いほどおいそれとは変えられない
808デフォルトの名無しさん
2017/08/29(火) 00:32:32.45ID:MFSwZwGT Perl は5.005まで。5.6からは別物。
809デフォルトの名無しさん
2017/08/29(火) 18:35:08.35ID:rhRVTFDq <?=>
810デフォルトの名無しさん
2017/08/29(火) 18:35:53.37ID:rhRVTFDq >>801
なにそれどうやって書くの?
なにそれどうやって書くの?
811デフォルトの名無しさん
2017/08/30(水) 09:00:08.40ID:Lglrs9g0812デフォルトの名無しさん
2017/08/30(水) 19:42:59.46ID:bbdqdnnx 環境によってはどうやってもアトミックにならんのでは
813デフォルトの名無しさん
2017/08/31(木) 15:10:50.45ID:zaIZgwYc $_ って正式名称はなに?
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 高市首相答弁を“引き出した”立民・岡田克也氏が改めて説明「なぜ慎重な答弁をされなかったのか。非常に残念に思っている」 ★2 [ぐれ★]
- 【速報】中国、水産物輸入停止と通達 「処理水」理由、日本政府へ ★7 [おっさん友の会★]
- 【次の一手】台湾問題で小林よしのり氏が私見「まさに戦争前夜」「ただちに徴兵制を敷いて、高市支持者を最前線へ」… [BFU★]
- 中国側が首相答弁の撤回要求、日本側拒否★7 [夜のけいちゃん★]
- 「高市人気」どこに? 自民候補が福島市長選で大敗、葛飾区議選でも苦戦 衆院早期解散論に冷や水 [1ゲットロボ★]
- 【ホタテ】中国が水産物輸入停止を伝達「ビクビクしながら…」北海道の水産業者からは落胆の声 [おっさん友の会★]
- 中国「水産物輸入停止は高市首相の発言が理由」 [256556981]
- 日本人、ついに気づく「あれ、日本が対中国で取れる対抗措置ってなくない…?」 [931948549]
- 【号外】中国外務省、高市首相が台湾関連の発言を撤回しなければ「断固たる対抗措置」を取らざるを得ないと述べた [115996789]
- 中国「次に禁止してほしいものを教えて」 [358382861]
- 【画像】外務省局長のあの写真、日本側に無許可で撮影されたものだったwwwwwwwww [834922174]
- 【速報】中国、水産物輸入停止★3 [989870298]
