CGIについての質問は板違いです。WEBプログラミング板でどうぞ。
CGIとPerlの区別がつかない人もWEBプログラミング板に行ってください。
(WEBプログラミング板: https://medaka.5ch.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.28.1)
▼前スレ
Perlについての質問箱 61箱目
http://toro.5ch.net/test/read.cgi/tech/1381561905/
Perlについての質問箱 62箱目
http://toro.5ch.net/test/read.cgi/tech/1385039352/
Perlについての質問箱 63箱目
https://mevius.5ch.net/test/read.cgi/tech/1392820583/
Perlについての質問箱 64箱目
レス数が900を超えています。1000を超えると表示できなくなるよ。
2019/02/01(金) 09:44:37.18ID:1/Kr4Qjk
803デフォルトの名無しさん
2020/11/28(土) 18:31:31.18ID:1bDz9VeK 「数で得る」というのがよく解らないが、timelocal()とlocaltime()を使えば、
多分、やりたいことができると思う。
多分、やりたいことができると思う。
804デフォルトの名無しさん
2020/12/03(木) 17:27:36.92ID:PrWVOzOn これから仕事ではじめてperlを使うんだけど、メッセージやメール出力などにマルチ言語対応が入ってる
resourceに言語ファイルをいれる形で実現したいけど、どのようにするのがいいか教えて下さい
複数のスクリプトを開発して連係させる予定
resourceに言語ファイルをいれる形で実現したいけど、どのようにするのがいいか教えて下さい
複数のスクリプトを開発して連係させる予定
805デフォルトの名無しさん
2020/12/05(土) 13:44:54.28ID:DP7JjxAq ヒアドキュメントの中で数式を使うやり方は?
@{[数式]}
のようにやってもエラーで動かなかった
@{[数式]}
のようにやってもエラーで動かなかった
806デフォルトの名無しさん
2020/12/05(土) 15:34:53.50ID:3OUqO/Qz >>802
Ruby on Rails なら、時刻計算用のライブラリがある
require 'active_support/time'
p Date.new( 2020, 2, 28 ).advance( days: 2 )
出力。うるう年
Sun, 01 Mar 2020
Ruby on Rails なら、時刻計算用のライブラリがある
require 'active_support/time'
p Date.new( 2020, 2, 28 ).advance( days: 2 )
出力。うるう年
Sun, 01 Mar 2020
807デフォルトの名無しさん
2020/12/05(土) 15:43:47.69ID:+/FrBp4K そんな感じの気楽で使いたい
$date = date->new('2020-12-05');
$date += 100;
($y, $m, $d) = ($date->year, $date->month, $date->day);
こんなん
$date = date->new('2020-12-05');
$date += 100;
($y, $m, $d) = ($date->year, $date->month, $date->day);
こんなん
808デフォルトの名無しさん
2020/12/05(土) 16:43:15.39ID:dBHdheKW >>805
おかしいな。それで合ってるように思えるんだが。
この辺りを読んで、何か誤解してないか確認したらいいかも。
https://perldoc.jp/docs/perl/5.26.1/perlref.pod
おかしいな。それで合ってるように思えるんだが。
この辺りを読んで、何か誤解してないか確認したらいいかも。
https://perldoc.jp/docs/perl/5.26.1/perlref.pod
809806
2020/12/05(土) 18:18:59.36ID:3OUqO/Qz 「perl 時刻 計算」で検索すれば?
日付・時刻を扱う標準モジュール、Time::Piece が標準で添付されています。
もっと便利なモジュールを、誰かが作っているかも
日付・時刻を扱う標準モジュール、Time::Piece が標準で添付されています。
もっと便利なモジュールを、誰かが作っているかも
810デフォルトの名無しさん
2020/12/05(土) 18:31:57.30ID:+/FrBp4K localtimeからスタートする時はそれが便利
何か基準の日付から計算しようとすると面倒になる
何か基準の日付から計算しようとすると面倒になる
811デフォルトの名無しさん
2020/12/05(土) 20:29:02.43ID:5ARiBM7n812デフォルトの名無しさん
2020/12/05(土) 23:54:20.43ID:DP7JjxAq813デフォルトの名無しさん
2020/12/06(日) 00:14:01.05ID:GZ1arJtc >>812
だからエラーの文面をはれっつーの。
でも、わかった。
「[]」の内側に書けるのは、式のリスト。
最後に「;」を書くのは、「式」でなく「文」というか。
しかし、それだとうまくいっても「aaawww1」と表示される気がするが、どうなの?w
だからエラーの文面をはれっつーの。
でも、わかった。
「[]」の内側に書けるのは、式のリスト。
最後に「;」を書くのは、「式」でなく「文」というか。
しかし、それだとうまくいっても「aaawww1」と表示される気がするが、どうなの?w
814532
2020/12/06(日) 00:15:36.74ID:1Uj+ZrCS print <<"eos";
@{[print "aaawww"]}
eos
$ perl aaawww.pl
aaawww1
;を省くと動くが、「1」とか余計なものがつくな
@{[print "aaawww"]}
eos
$ perl aaawww.pl
aaawww1
;を省くと動くが、「1」とか余計なものがつくな
815デフォルトの名無しさん
2020/12/06(日) 00:43:41.05ID:Znd8Qdfl >>813
CGI 実行エラー syntax error at test.cgi line 10, near ""aaawww";"
Execution of test.cgi aborted due to compilation errors.
CGI 実行エラー syntax error at test.cgi line 10, near ""aaawww";"
Execution of test.cgi aborted due to compilation errors.
816デフォルトの名無しさん
2020/12/06(日) 01:06:20.00ID:rqNKNacS 単なる構文エラー
無名リストの中に裸のセミコロンがあったらまずいでしょ
["A", "B", 3, ";"] OK
["A", "B", 3, ;] エラー
余計な1じゃなくてprint関数の返り値
printが成功したので真(1)を返して無名リストの要素になった
printで"aaawww"が表示された後デリファレンスされて展開された1がヒアドキュメントで表示される
無名リストの中に裸のセミコロンがあったらまずいでしょ
["A", "B", 3, ";"] OK
["A", "B", 3, ;] エラー
余計な1じゃなくてprint関数の返り値
printが成功したので真(1)を返して無名リストの要素になった
printで"aaawww"が表示された後デリファレンスされて展開された1がヒアドキュメントで表示される
817デフォルトの名無しさん
2020/12/06(日) 01:06:31.00ID:GZ1arJtc818デフォルトの名無しさん
2020/12/06(日) 01:19:08.97ID:d/9HsImJ >>802
今更だけど日付をエポック秒で表して日数×24*60*60を足すんじゃだめ?
車輪の再発明というかただの製作を承知で、自分で日付変換の関数を一通り作ったらそれで十分だった
便利そうなライブラリを探そうとしたこともあるけど、オブジェクト指向的なやつだと結局その
オブジェクトを介した変換が頻出することになってスラスラ書けないなあと思ったのです。
もし今後UTCとかJSTとか出てきたときはそのときまた考える。
今更だけど日付をエポック秒で表して日数×24*60*60を足すんじゃだめ?
車輪の再発明というかただの製作を承知で、自分で日付変換の関数を一通り作ったらそれで十分だった
便利そうなライブラリを探そうとしたこともあるけど、オブジェクト指向的なやつだと結局その
オブジェクトを介した変換が頻出することになってスラスラ書けないなあと思ったのです。
もし今後UTCとかJSTとか出てきたときはそのときまた考える。
819デフォルトの名無しさん
2020/12/06(日) 02:06:04.21ID:fHRDTQ7E PerlのYAML関連のモジュールが全部重くて厳しい
高速なYAMLモジュールはないのか?
高速なYAMLモジュールはないのか?
820デフォルトの名無しさん
2020/12/06(日) 10:37:45.21ID:kLx/M/5Z まずは高速なCのライブラリを見つけます
821デフォルトの名無しさん
2020/12/06(日) 11:42:16.72ID:BlX3SIQO >>803 だが、>>802 の質問は>>803 で終わったと思ったのだが、不親切だった?
例えば2019年12月1日から365日後の日付は、次のようにすれば得られる。
use Time::Local;
$year=2019;$mon=12;$mday=1;$hours=12;$min=0;$sec=0;
$intvl=365;
$basetime = timelocal($sec, $min, $hours, $mday, $mon-1, $year-1900);
$basetime += $intvl*24*60*60;
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =localtime($basetime);
$mon+=1;$year+=1900;
print STDERR "$year.$mon.$mday\n";
例えば2019年12月1日から365日後の日付は、次のようにすれば得られる。
use Time::Local;
$year=2019;$mon=12;$mday=1;$hours=12;$min=0;$sec=0;
$intvl=365;
$basetime = timelocal($sec, $min, $hours, $mday, $mon-1, $year-1900);
$basetime += $intvl*24*60*60;
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =localtime($basetime);
$mon+=1;$year+=1900;
print STDERR "$year.$mon.$mday\n";
822デフォルトの名無しさん (ワッチョイ be3b-cfMa)
2020/12/06(日) 11:58:40.89ID:5Rf1GOX10 見るからに面倒臭い
823デフォルトの名無しさん
2020/12/07(月) 09:18:58.50ID:zfvnE2zk $basetime = timelocal_nocheck($sec, $min, $hours, $mday+$intvl, $mon-1, $year-1900);
824デフォルトの名無しさん
2020/12/07(月) 09:43:24.77ID:UAiCPmDo Time::Piece はよくできてて、何かのログとかに現在時刻を書き出す、
とかの用途には十分に使える
でも、時刻計算や日数計算はあまり考慮されていない
現在時刻からの計算はできても、任意の時刻からだと弱い
とかの用途には十分に使える
でも、時刻計算や日数計算はあまり考慮されていない
現在時刻からの計算はできても、任意の時刻からだと弱い
825デフォルトの名無しさん
2020/12/07(月) 14:03:32.45ID:tC78i6pr >>807
use Time::Piece;
use Time::Seconds;
my $day = Time::Piece->strptime('2020-12-05', '%Y-%m-%d');
$day += ONE_DAY * 100;
print $day->date, "\n";
print $day->year, "\n";
print $day->mon, "\n";
print $day->mday, "\n";
use Time::Piece;
use Time::Seconds;
my $day = Time::Piece->strptime('2020-12-05', '%Y-%m-%d');
$day += ONE_DAY * 100;
print $day->date, "\n";
print $day->year, "\n";
print $day->mon, "\n";
print $day->mday, "\n";
826デフォルトの名無しさん
2020/12/07(月) 14:21:35.27ID:UAiCPmDo まあ、strptime さえ目を瞑れば
こんなもん、何か見ないと書けない
こんなもん、何か見ないと書けない
827デフォルトの名無しさん
2020/12/07(月) 15:40:13.93ID:15jj6qfl use POSIX; を宣言してCの標準関数に似た時刻処理機能を使うのが普通じゃないの?
Cの時刻処理サンプルコードを円滑にPerlに移植できるよ。
Cの時刻処理サンプルコードを円滑にPerlに移植できるよ。
828デフォルトの名無しさん
2020/12/07(月) 17:17:12.82ID:VC6/tHTg829532
2020/12/07(月) 21:57:48.14ID:WG5ppFXF Time::Pieceの弱点は
strptime()で作ったインスタンスのtimeゾーンをいじれないとこかな?
後1つなんか弱手あった気がするが忘れた
strptime()で作ったインスタンスのtimeゾーンをいじれないとこかな?
後1つなんか弱手あった気がするが忘れた
830デフォルトの名無しさん
2020/12/07(月) 22:38:30.88ID:UAiCPmDo strptimeはpythonでもrubyでも同じだから、もう慣れなんだろうな
'YYYY-MM-DD' とかではあかんかったのか
'YYYY-MM-DD' とかではあかんかったのか
831デフォルトの名無しさん
2020/12/08(火) 04:35:26.34ID:65P2yCaW >>821
timeLocal()の年は1900引かない方がいいよ。これちょっとCのライブラリとは違うんだよ。詳しくはドキュメント読んで。
timeLocal()の年は1900引かない方がいいよ。これちょっとCのライブラリとは違うんだよ。詳しくはドキュメント読んで。
832デフォルトの名無しさん
2020/12/08(火) 04:36:34.48ID:65P2yCaW あ。タイプミス。timelocal()ね。
833デフォルトの名無しさん
2020/12/08(火) 23:53:37.62ID:VS4VHEi1 すみません、ソートで教えて欲しいんですが下記のようにみたいな枝番号が付いてる文字列をハッシュのキーとして
ハイフン前の数値でソートした後にハイフン後の数値でソートしたいのですが
普通に$a <=> $bだとハイフンの後の値がバラバラになって上手くいきません
キーを作る際に別々に作ってループ増やすくらいしか自分には解決方法が無いのですが、スマートに出来る方法は無いのでしょうか?
1-1
1-2
2-1
2-2
3-1
ハイフン前の数値でソートした後にハイフン後の数値でソートしたいのですが
普通に$a <=> $bだとハイフンの後の値がバラバラになって上手くいきません
キーを作る際に別々に作ってループ増やすくらいしか自分には解決方法が無いのですが、スマートに出来る方法は無いのでしょうか?
1-1
1-2
2-1
2-2
3-1
834デフォルトの名無しさん
2020/12/09(水) 00:31:36.73ID:LWKBPFtb >>833
シュワルツ変換で検索!
たとえば :
mapでソート用の値として、前の数字×10000+後ろの数字の値をつくって、それともとの値のペアにする。
それを<=>でソートする。
mapで、ソート結果からもとのデータ部分を取り出す。
シュワルツ変換で検索!
たとえば :
mapでソート用の値として、前の数字×10000+後ろの数字の値をつくって、それともとの値のペアにする。
それを<=>でソートする。
mapで、ソート結果からもとのデータ部分を取り出す。
835デフォルトの名無しさん
2020/12/09(水) 00:39:46.90ID:LWKBPFtb 要は、map{...} sort{...} map{...}となる。
変換のためのループが2回入る(map)が、記述としてはあっさりなので、特殊なソートをしたいときにはよく使われる有名な方法。
伝わるかな?w
変換のためのループが2回入る(map)が、記述としてはあっさりなので、特殊なソートをしたいときにはよく使われる有名な方法。
伝わるかな?w
836デフォルトの名無しさん
2020/12/09(水) 08:45:38.11ID:UMU4oc+t それで書けるなら、sort { } でも書けるよね
837デフォルトの名無しさん
2020/12/09(水) 09:35:02.27ID:sn/SI4a+ >>833
こんな感じかな。デバッグはしていないが。
@newlist = sort compare @oldlist;
sub compare{
my ($ap, $bp) = @_;
($ap1, $ap2) = $ap=~/([0-9]+)\-([0-9]+)/;
($bp1, $bp2) = $bp=~/([0-9]+)\-([0-9]+)/;
return 1 if $ap1 > $bp1
return -1 if $ap1 < $bp1
# $ap1 == $bp1;
return 1 if $ap2 > $bp2;
return -1;
}
こんな感じかな。デバッグはしていないが。
@newlist = sort compare @oldlist;
sub compare{
my ($ap, $bp) = @_;
($ap1, $ap2) = $ap=~/([0-9]+)\-([0-9]+)/;
($bp1, $bp2) = $bp=~/([0-9]+)\-([0-9]+)/;
return 1 if $ap1 > $bp1
return -1 if $ap1 < $bp1
# $ap1 == $bp1;
return 1 if $ap2 > $bp2;
return -1;
}
838デフォルトの名無しさん
2020/12/09(水) 10:27:05.71ID:LWKBPFtb839デフォルトの名無しさん
2020/12/09(水) 10:46:35.52ID:zREBomTd sort { s1($a) <=> s1($b) } keys %x;
sub s1 {
shift =~ /(¥d+)-(¥d+)/ && 100*$1+$2
}
sortならこんなかんじ
sub s1 {
shift =~ /(¥d+)-(¥d+)/ && 100*$1+$2
}
sortならこんなかんじ
840デフォルトの名無しさん
2020/12/09(水) 10:47:56.70ID:UMU4oc+t 順番が変わるだけで処理量は変わらんでしょう
どっちにしろ重い
次にソートする時はソート対象が変わっているんだから、キャッシュできない
有効な局面もあるんだろうけど、今回に関してはトリッキーなだけでメリットがない
どっちにしろ重い
次にソートする時はソート対象が変わっているんだから、キャッシュできない
有効な局面もあるんだろうけど、今回に関してはトリッキーなだけでメリットがない
841デフォルトの名無しさん
2020/12/09(水) 10:51:05.82ID:UMU4oc+t 次のソートじゃなくて、1回のソート内部の複数の比較に対してか
あー、確かに速くなりそうな気がする
処理系が気を利かせて変わらない気もする
あー、確かに速くなりそうな気がする
処理系が気を利かせて変わらない気もする
842デフォルトの名無しさん
2020/12/09(水) 11:29:48.25ID:LWKBPFtb843デフォルトの名無しさん
2020/12/09(水) 12:58:19.84ID:UMU4oc+t 内部の話だからsayでは判らんだろ
関数で評価しないといけないと判っていて、動的に処理する必要も無いんだから、
評価済みのテーブルを内部に持たせようというのは自然な発想
関数で評価しないといけないと判っていて、動的に処理する必要も無いんだから、
評価済みのテーブルを内部に持たせようというのは自然な発想
844デフォルトの名無しさん
2020/12/09(水) 13:12:15.55ID:/81rDyGm845デフォルトの名無しさん
2020/12/09(水) 13:44:43.94ID:UMU4oc+t 判ってないのかな
処理速度に配慮した処理系があっても不思議ではないという話
手元で試して遅かったとしても、全ての処理系に対する証明にはならない
処理速度に配慮した処理系があっても不思議ではないという話
手元で試して遅かったとしても、全ての処理系に対する証明にはならない
846デフォルトの名無しさん
2020/12/09(水) 14:16:41.19ID:AA5LXV3h >>845
痛々しいからもうやめとけ
痛々しいからもうやめとけ
847デフォルトの名無しさん
2020/12/09(水) 14:32:22.15ID:LWKBPFtb >>845
Perlの「全ての処理系」て。w
Perlの「全ての処理系」て。w
848デフォルトの名無しさん
2020/12/09(水) 15:17:55.01ID:UMU4oc+t そもそも重いかどうかが疑問で、どっちでやっても一瞬で終わるのが普通
それなら読みやすい方が優れている
重くて困ってから対策を考えればいい
それなら読みやすい方が優れている
重くて困ってから対策を考えればいい
849デフォルトの名無しさん
2020/12/09(水) 16:44:07.55ID:qaSCdqDS map {
$_->[0];
} sort {
$a->[1] <=> $b->[1] || $a->[2] <=> $b->[2];
} map {
[$_, /(\d+)/g ];
}
読みにくい…かなあ?
$_->[0];
} sort {
$a->[1] <=> $b->[1] || $a->[2] <=> $b->[2];
} map {
[$_, /(\d+)/g ];
}
読みにくい…かなあ?
850デフォルトの名無しさん
2020/12/09(水) 17:06:18.35ID:8NKLSi5o >>849
他の言語の人が見たら発狂しそう
他の言語の人が見たら発狂しそう
851デフォルトの名無しさん
2020/12/09(水) 18:15:36.35ID:UMU4oc+t 別に短く書かなくていいんだよ
@r = sort s2 @a;
sub s1 {
my $str = shift;
$str =~ /(\d+)\-(\d+)/;
return $1 * 100 + $2;
}
sub s2 {
return s1($a) <=> s1($b);
}
@r = sort s2 @a;
sub s1 {
my $str = shift;
$str =~ /(\d+)\-(\d+)/;
return $1 * 100 + $2;
}
sub s2 {
return s1($a) <=> s1($b);
}
852デフォルトの名無しさん
2020/12/09(水) 18:16:58.18ID:xAMitlRd 発狂しない人が使えば良いよ
853デフォルトの名無しさん
2020/12/09(水) 19:43:12.41ID:LWKBPFtb854デフォルトの名無しさん
2020/12/09(水) 19:45:15.15ID:LWKBPFtb855デフォルトの名無しさん
2020/12/09(水) 22:17:09.12ID:rsuX7ND7 ハッシュテーブルにs1($val)の戻り値を保存して、そのハッシュテーブルを使って比較関数を呼び出すとかするのが普通でしょ。
856849
2020/12/10(木) 06:03:00.77ID:+FxPMgzN857デフォルトの名無しさん
2020/12/10(木) 16:08:39.86ID:smJEm1Fb 2桁前提なんだろうな
858デフォルトの名無しさん
2020/12/10(木) 19:59:40.99ID:g17Qy/zb859デフォルトの名無しさん
2020/12/11(金) 03:24:48.11ID:lklp228q 考え方は同じだけど最初からソート用の値をデータに持たせてみる。
my %x = (
'3-1' => ['e', 301],
'1-2' => ['b', 102],
.... ,
);
sort { $x{$a}[1] <=> $x{$b}[1] } keys %x;
my %x = (
'3-1' => ['e', 301],
'1-2' => ['b', 102],
.... ,
);
sort { $x{$a}[1] <=> $x{$b}[1] } keys %x;
860デフォルトの名無しさん
2020/12/11(金) 03:42:00.36ID:Hz2bdcAQ 複数キーでのソートに帰着させるべきなんだろうな
1-1-1 も許容する、とかになった瞬間に破綻する
1-1-1 も許容する、とかになった瞬間に破綻する
861デフォルトの名無しさん
2020/12/11(金) 04:01:52.35ID:Hz2bdcAQ sub s1 {
my @a = split /\-/, $a;
my @b = split /\-/, $b;
my $dim = @a > @b ? @a : @b;
for my $i (0 .. $dim) {
my $cmp = $a[$i] <=> $b[$i];
return $cmp if $cmp;
}
return 0;
}
my @a = split /\-/, $a;
my @b = split /\-/, $b;
my $dim = @a > @b ? @a : @b;
for my $i (0 .. $dim) {
my $cmp = $a[$i] <=> $b[$i];
return $cmp if $cmp;
}
return 0;
}
862856
2020/12/11(金) 06:10:31.03ID:LwDR4/oY >> 833 には数値の値域については何も書かれてないんだから
勝手に想定しない方がいいと想うよ。
どうしても比較を簡略化したいなら pack 関数で数値を全部
ビッグエンディアンで並べればいいんじゃないかな。
勝手に想定しない方がいいと想うよ。
どうしても比較を簡略化したいなら pack 関数で数値を全部
ビッグエンディアンで並べればいいんじゃないかな。
863デフォルトの名無しさん
2020/12/11(金) 10:41:01.46ID:vQm1aiEb864デフォルトの名無しさん
2020/12/11(金) 10:50:54.59ID:vQm1aiEb865デフォルトの名無しさん
2020/12/11(金) 11:20:18.13ID:Hz2bdcAQ 1-1があるなら1-1-1もあると予測するのは自然な拡張
1-1-1-... に無限に対応できるように作っておいて、
その特殊ケースとして要件を満たす、で十分
アルファベットにも対応するのは次元が違う
1-1-1-... に無限に対応できるように作っておいて、
その特殊ケースとして要件を満たす、で十分
アルファベットにも対応するのは次元が違う
866デフォルトの名無しさん
2020/12/11(金) 19:40:49.33ID:V1LdBVWq867デフォルトの名無しさん
2020/12/11(金) 20:46:31.45ID:vQm1aiEb868デフォルトの名無しさん
2020/12/11(金) 21:01:49.19ID:jm3zE7RU 普段は過疎ってるのに少し書き込みがあるとクソ雑魚が湧いてきてグズグズ文句たれる
頭の中どうなってんだろうな
頭の中どうなってんだろうな
869デフォルトの名無しさん
2020/12/11(金) 22:34:31.89ID:Hz2bdcAQ んでんでんで
870デフォルトの名無しさん
2020/12/11(金) 22:41:46.66ID:pFqzegRi >>837 だが、実は、このコードは、オレが実際に、数字とかアルファベットとかが
複雑に絡んだ文字列を、ある規則に従ってソートするために作ったものを
流用したんだ。だから、応用範囲が広いという点では、これがいいと思うけどな。
複雑に絡んだ文字列を、ある規則に従ってソートするために作ったものを
流用したんだ。だから、応用範囲が広いという点では、これがいいと思うけどな。
871デフォルトの名無しさん
2020/12/11(金) 22:48:30.39ID:Hz2bdcAQ sortの関数って@_で受けれるの?
872デフォルトの名無しさん
2020/12/11(金) 23:30:45.59ID:vQm1aiEb873デフォルトの名無しさん
2020/12/11(金) 23:38:00.26ID:Hz2bdcAQ どう見ても章のタイトルとかそんなんなので、1000も無いよ
高速化の工夫は遅くて困ってから
高速化の工夫は遅くて困ってから
874532
2020/12/12(土) 00:28:14.42ID:tTwN9OuS >>833
perlのsort()アルゴリズムは5,8以降マージソートになってsort結果は安定なアルゴリズムなので
手短にコードを書くなら右の数字でsortしてから左の数字でsortすれば所望の結果が得られる。以下サンプル実装
use List::Util 'shuffle';
%h = map{$_ => $i++} shuffle qw{1-1 1-2 1-3 2-1 2-2 2-3 3-1 3-2 3-3};
use feature qw{say signatures}; no warnings experimental;
@k1 = keys %h;
say "@k1";
sub f($s) { [$s =~ /(\d+)/g, $s]};
@k2 = map{$$_[2]} sort{$a->[0] <=> $b->[0]} sort{$a->[1] <=> $b->[1]} map{f $_} @k1;
say "@k2";
実行結果
~ $ perl 64_833_n-n_sort_1.pl
1-1 2-3 3-3 1-2 3-1 2-2 2-1 1-3 3-2
1-1 1-2 1-3 2-1 2-2 2-3 3-1 3-2 3-3
言語処理系内部のsort()関数のアルゴリズムに依存しない書き方がしたいなら
左と右の数値で二段階のソートをするか、右の数字と左の数値で順位に一貫性のあるキーを作って
一段階のソートで済ませる方法もあると思う。
そういったサンプル実装を見たいのであれば、時間があればくけれども…
perlのsort()アルゴリズムは5,8以降マージソートになってsort結果は安定なアルゴリズムなので
手短にコードを書くなら右の数字でsortしてから左の数字でsortすれば所望の結果が得られる。以下サンプル実装
use List::Util 'shuffle';
%h = map{$_ => $i++} shuffle qw{1-1 1-2 1-3 2-1 2-2 2-3 3-1 3-2 3-3};
use feature qw{say signatures}; no warnings experimental;
@k1 = keys %h;
say "@k1";
sub f($s) { [$s =~ /(\d+)/g, $s]};
@k2 = map{$$_[2]} sort{$a->[0] <=> $b->[0]} sort{$a->[1] <=> $b->[1]} map{f $_} @k1;
say "@k2";
実行結果
~ $ perl 64_833_n-n_sort_1.pl
1-1 2-3 3-3 1-2 3-1 2-2 2-1 1-3 3-2
1-1 1-2 1-3 2-1 2-2 2-3 3-1 3-2 3-3
言語処理系内部のsort()関数のアルゴリズムに依存しない書き方がしたいなら
左と右の数値で二段階のソートをするか、右の数字と左の数値で順位に一貫性のあるキーを作って
一段階のソートで済ませる方法もあると思う。
そういったサンプル実装を見たいのであれば、時間があればくけれども…
875532
2020/12/12(土) 00:42:28.87ID:tTwN9OuS つか、実は Tie::IxHash を使ってhashに登録したデータの順番を維持して取り出せれば
いいだけの話だったりしてな。しらんけど
いいだけの話だったりしてな。しらんけど
876デフォルトの名無しさん
2020/12/12(土) 00:47:36.64ID:iq4I9JA8 >>867
アホだなあ
アホだなあ
878デフォルトの名無しさん
2020/12/12(土) 01:06:54.59ID:4UtPcEnB >>876
Perlでバッファオーバーランを実装する方法を教えてください。w
Perlでバッファオーバーランを実装する方法を教えてください。w
879デフォルトの名無しさん
2020/12/12(土) 02:31:23.48ID:gfhxsiY6 バッファオーバーランつまり out of range なんてすぐ起こせるでしょ。
880デフォルトの名無しさん
2020/12/12(土) 03:38:37.71ID:4UtPcEnB881862
2020/12/12(土) 09:07:56.06ID:K38oRjDr pack に誰も食いついてこないのはちょっと寂しいな。
正しくやれば C でさえ 1 回の memcmp で比較が済むのだが。
ましてや、Perl の pack/unpack は Perl4 の時代からある超便利関数なのだが。
まあ、「ひょっとして比較をシンプルにしたいのかな?」と思ったから書いただけだし
今回のニーズには合ってても万能というわけではないし
自分が良いと思う方法でやればいいと思うよ。
正しくやれば C でさえ 1 回の memcmp で比較が済むのだが。
ましてや、Perl の pack/unpack は Perl4 の時代からある超便利関数なのだが。
まあ、「ひょっとして比較をシンプルにしたいのかな?」と思ったから書いただけだし
今回のニーズには合ってても万能というわけではないし
自分が良いと思う方法でやればいいと思うよ。
882デフォルトの名無しさん
2020/12/12(土) 09:26:02.24ID:kEr/Zqiv 数1つあたりのbit数が決められないがな
何とかしてmap使いたいから無理筋言ってるだけとしか
何とかしてmap使いたいから無理筋言ってるだけとしか
883532
2020/12/12(土) 10:42:34.69ID:+ekv//0b >>833 >>874に書いた左の数字と右の数値両方で順位に一貫性のあるキーを作って一回でsortするサンプル
数値は4桁以下であることを仮定してます。
use List::Util 'shuffle';
%h = map{$_ => $i++} shuffle qw{1-1 1-2 1-3 2-1 2-2 2-3 3-1 3-2 3-3};
@k1 = keys %h;
print "@k1\n";
@kk = map{[sprintf("%4d%4d", /(\d+)/g), $_]} @k1;
@k2 = map{$$_[1]} sort{$$a[0] cmp $$b[0]} @kk;
print "@k2\n";
数値は4桁以下であることを仮定してます。
use List::Util 'shuffle';
%h = map{$_ => $i++} shuffle qw{1-1 1-2 1-3 2-1 2-2 2-3 3-1 3-2 3-3};
@k1 = keys %h;
print "@k1\n";
@kk = map{[sprintf("%4d%4d", /(\d+)/g), $_]} @k1;
@k2 = map{$$_[1]} sort{$$a[0] cmp $$b[0]} @kk;
print "@k2\n";
885デフォルトの名無しさん
2020/12/12(土) 13:20:14.94ID:4UtPcEnB >>881
慣れたヤツには最適解過ぎ、慣れてないヤツには意義がわからん、ということで、そんなに食いつきようがないやろ。w
慣れたヤツには最適解過ぎ、慣れてないヤツには意義がわからん、ということで、そんなに食いつきようがないやろ。w
886デフォルトの名無しさん
2020/12/16(水) 23:33:00.22ID:qMOR0fCG >>833
もしそれが桁数固定で、例えばその例のように一桁の数、ハイフン、一桁の数という文字列ならば、何も考えずにそのまま文字列として比較して sort すればいい。つまりただ sort するだけ。
もしそれが桁数固定で、例えばその例のように一桁の数、ハイフン、一桁の数という文字列ならば、何も考えずにそのまま文字列として比較して sort すればいい。つまりただ sort するだけ。
887デフォルトの名無しさん
2020/12/17(木) 05:05:50.95ID:fz9fvgi4 そんなもんは9で終わる訳がなくて10も100もある筈、と自然に拡張して考える
それと同様に、枝番号ならサブサブセクション以降もある筈、という拡張は
自然なのに、そっちには思い至らないんだよな
それと同様に、枝番号ならサブサブセクション以降もある筈、という拡張は
自然なのに、そっちには思い至らないんだよな
888デフォルトの名無しさん
2020/12/17(木) 09:44:28.00ID:RUflbAwb889デフォルトの名無しさん
2020/12/18(金) 08:38:15.55ID:1Xc4Ax1A 「数値でソートしたい」って最初から書いてあるだろ……
890デフォルトの名無しさん
2020/12/18(金) 08:53:35.39ID:lJHaaS7Y 今だけはいいけどすぐに駄目になりそうな設計を、
裏技見つけたみたいにやりたがる奴がいるんだよな
ユーザは予想を超えた無茶をしてくるものなのに
裏技見つけたみたいにやりたがる奴がいるんだよな
ユーザは予想を超えた無茶をしてくるものなのに
891デフォルトの名無しさん
2020/12/18(金) 09:55:06.92ID:Kz3E+lfW Keep It Simple, Stupid
892デフォルトの名無しさん
2020/12/18(金) 09:58:16.29ID:lJHaaS7Y よい設計というのは自然とシンプルになるものなんだよ
893849
2020/12/18(金) 16:30:11.78ID:1Xc4Ax1A sub Schwalts {
@tmp = @_;
@tmp = map { [$_, /(\d+)/g ] } @tmp;
@tmp = sort { $a->[1] <=> $b->[1] || $a->[2] <=> $b->[2] } @tmp;
( map { $_->[0] } @tmp);
}
を短く書いたのがシュワルツ変換だよ
くらいの説明はした方がいいのかな。
@tmp = @_;
@tmp = map { [$_, /(\d+)/g ] } @tmp;
@tmp = sort { $a->[1] <=> $b->[1] || $a->[2] <=> $b->[2] } @tmp;
( map { $_->[0] } @tmp);
}
を短く書いたのがシュワルツ変換だよ
くらいの説明はした方がいいのかな。
894デフォルトの名無しさん
2020/12/18(金) 21:33:33.71ID:rUPjISbN まだやってんのかw
895デフォルトの名無しさん
2020/12/22(火) 10:15:20.24ID:YhckWNJa 最近raku触ってるけど面白すぎるわこれ、識別子をパース?して組み合わせるの楽しい
もうこれ半分lispだろ
もうこれ半分lispだろ
896デフォルトの名無しさん
2020/12/22(火) 12:14:37.88ID:/kVuwMjM 演算子の前後に空白が必須なの、なんかイヤじゃない?
ツメツメで書きたいのに。
Perl6のころだけど、オレが降りた理由のひとつ。
ツメツメで書きたいのに。
Perl6のころだけど、オレが降りた理由のひとつ。
897デフォルトの名無しさん
2020/12/22(火) 16:09:49.34ID:Rxnt3reZ898デフォルトの名無しさん
2020/12/22(火) 16:21:28.35ID:Mi4b/BA1 言語なんて、他の言語のいいとこ取りで進化していくからな
常に便利になった部分と実験的な部分がある
常に便利になった部分と実験的な部分がある
899デフォルトの名無しさん
2020/12/27(日) 18:10:18.92ID:pJIjrBUp ローカルで一番最初にperlの呼び出しの部分は#!c:/Perl/bin/perl.exeって書くけど
サーバーに上げるときは毎回#!/user/local/perlというように書き直すのがめんどうだけど
#!/user/local.perlのまんまでもローカルで動かす方法ありますか?
サーバーに上げるときは毎回#!/user/local/perlというように書き直すのがめんどうだけど
#!/user/local.perlのまんまでもローカルで動かす方法ありますか?
900デフォルトの名無しさん
2020/12/27(日) 19:39:12.76ID:CEWAcbKQ あれ?
/usr/local/perlのままでもいけるんじゃないの?
Windowsはそこのパスを見てなかったような。
/usr/local/perlのままでもいけるんじゃないの?
Windowsはそこのパスを見てなかったような。
901デフォルトの名無しさん
2020/12/27(日) 19:46:23.03ID:/HQdSjMP Apacheは見てる
そんでApacheのあるドライブにuser/localのフォルダ作ってperl.exeをコピーしたら動くよ
そんでApacheのあるドライブにuser/localのフォルダ作ってperl.exeをコピーしたら動くよ
902デフォルトの名無しさん
2020/12/27(日) 21:30:33.15ID:CEWAcbKQ そうだっけか?
ちなみに、もしそのファイルに拡張子があるならレジストリで指定する方法もある。
「windows apache レジストリ 拡張子」で検索!
ちなみに、もしそのファイルに拡張子があるならレジストリで指定する方法もある。
「windows apache レジストリ 拡張子」で検索!
レス数が900を超えています。1000を超えると表示できなくなるよ。
ニュース
- 習政権、高市首相への態度硬化 台湾有事発言で連日非難 中国 ★11 [ぐれ★]
- 日本損失1.7兆円に修正 中国渡航自粛の影響試算 [蚤の市★]
- 国内ホテル、既にキャンセルも 訪日客関連業界、事態見守る ★3 [蚤の市★]
- 「どうしようもない」 ため息つくアジアの玄関口 中国の訪日自粛で−福岡市 [蚤の市★]
- NHK、受信料の未払い世帯に督促強化へ 民事手続きの新組織を設置 差し押さえなどの強制執行も ★2 [1ゲットロボ★]
- 橋下徹氏 外務省幹部の訪中受け「口だけ番長」へ痛烈指摘 「喧嘩は日本の完敗…なんとかっこ悪い日本か」 [冬月記者★]
- 【実況】博衣こよりのえちえち朝こよ🧪 ★2
- 【実況】博衣こよりのえちえち朝こよ🧪
- Full Count、THE ANSWER、ENCOUNT、Hint-Pot… 日本人をホルホル漬けにしてくれる「Creative2」サイトの魅力 [452836546]
- カカロット、腰痛い
- 【!?】高市早苗「靖国神社電撃参拝プラン」浮上!これもう戦争だろ… [481941988]
- 【超悲報】中国への武力行使、世論調査で「賛成」「どちらかといえば賛成」48.8% 「反対」「どちらかといえば反対」の44.2%を上回る [314039747]
