Ruby 初心者スレッド Part 23 at TECH
[2ch|▼Menu]
[前50を表示]
450:デフォルトの名無しさん
08/12/13 00:08:10
>>448
Tenjin ってのが速いらしいけど、使ったことないから別にお勧めってわけでもない。
URLリンク(www.kuwata-lab.com)

451:デフォルトの名無しさん
08/12/13 07:29:20
>>448
俺のオススメはTenjinだけど
この辺のライブラリはかなり数があるので、いくつか試して目的に合った奴を使うと良いんじゃないかな
Rubyist Magazine最新号あたりの記事も参考に

ちなみに普通のCGIアプリで使うなら、Amrita2はRubyGemsとHpricotを使っているためオススメできない
(というか普通のレンタルサーバ環境ではまず動かない)
amrita-alteredの方が良いと思う。ただし動作がかなり重いことには注意

452:デフォルトの名無しさん
08/12/13 07:53:50
RDとかではめんどいからテンプレートエンジンが隆盛なんだと思う
決定版がないんだよねという話は5年くらい前からしてる気がするが

453:デフォルトの名無しさん
08/12/13 08:07:15
そもそもテンプレートエンジンに「ただ一つの決定版」って要るのか?
今の状況はけっこう理想的だと思うけど

454:デフォルトの名無しさん
08/12/13 10:35:39
元のファイルを読み込んで新規にファイルを作成し、
その内容を置換する作業を一括してやりたいと思っています。
色々と実験しているのですが通常の置換はできても正規表現による置換ができません。
試している元のファイル「 in.txt 」の内容は、

 |青空文庫《あおぞらぶんこ》
 へのへの

です。この内容を出力して置換するために書いた「 test.rb 」の内容が次です。

open("in.txt","r"){ |元ファイル|
 open("out.txt","w"){ |出力と置換後のファイル|
  while line = 元ファイル.gets
    line.gsub!("(|)(.+?)(《)(.+?)(》)","\4\3\2\1") #正規表現による置換。変化なし。
    line.gsub!("へのへの","もへじ")             #通常の置換。OK。
    出力と置換後のファイル.puts line
  end
 }
}

これによって出力された「 out.txt 」の内容が次のものです。

 |青空文庫《あおぞらぶんこ》
 もへじ

通常の置換は成功していますが、正規表現による置換に変化がありません。
どうすれば良いのでしょうか。

455:デフォルトの名無しさん
08/12/13 10:41:01
あんちゃん、praggerに関するスレってないん?

456:デフォルトの名無しさん
08/12/13 10:42:49
>>454
line.gsub(/(|)(.+?)(《)(.+?)(》)/,"\4\3\2\1") じゃまいか

457:デフォルトの名無しさん
08/12/13 10:47:15
'\4\3\2\1' こうだろ

458:デフォルトの名無しさん
08/12/13 11:03:27
>>448
ふつうにERBでええやん
URLリンク(jp.rubyist.net)
Tenjinは日本語の解説がないからこのレベルの初心者にはムリだと思う

459:デフォルトの名無しさん
08/12/13 11:08:08
>>458
erb より eruby の方が手軽じゃない?

1行目に #!/usr/bin/env eruby って書いておいて、
拡張子を cgi にしておけば普通のCGIと変わらず動くし。

460:デフォルトの名無しさん
08/12/13 11:09:49
>>456
>>457
ありがとうございます。

 line.gsub!(/(|)(.+?)(《)(.+?)(》)/,'\4\3\2\1')

で出来ました!
正規表現はスラッシュで、
後方参照はシングルクォートで囲む必要があるんですね。
すごく勉強になりました。

このスレの皆さんのおかげで本当に助かります。
あらためて感謝します。

461:デフォルトの名無しさん
08/12/13 11:47:48
ラ 出来ました!
懿「ォ めくらっぽう滅茶苦茶やってたらたまたま動作しました

462:デフォルトの名無しさん
08/12/13 13:05:38
gsubでブロック紹介しない時点でなあ…

463:デフォルトの名無しさん
08/12/13 13:37:05
strscanらぶ

464:デフォルトの名無しさん
08/12/13 13:42:35
>>458
今ならERbよりErubisの方が良くないか?

>>459
まず、erubyのインストールが厄介なのでは

465:デフォルトの名無しさん
08/12/13 14:00:56
各行の先頭に連番を振ることはできませんか。
「行数=挿入する数字」で良いんですが。

466:デフォルトの名無しさん
08/12/13 14:01:26
あのへんはサーバ上で動かすための設定やインストールが面倒でなあ…
ローカルでスクリプトとして使うならそれほどでもないんだが

467:デフォルトの名無しさん
08/12/13 14:03:07
>>465
各行に対して、正規表現の文頭を数字で置換しれ
改行区切りで配列にしてしまうのが簡単だと思う
joinでくっつけるときの改行コードは元の改行にしておくこと

468:デフォルトの名無しさん
08/12/13 14:09:35
str = "a
bb
ccc
dddd"
lines = Array.new
str.to_a.each_with_index do |e, n|
lines.push(e.sub(/^/){"#{n+1}: "})
end
print lines.join


結果

1: a
2: bb
3: ccc
4: dddd

このまま使うと2桁3桁のとき数字表示が汚くなるが、そのへんは自分で考えれ

469:デフォルトの名無しさん
08/12/13 17:17:48
>>467>>468
親切にありがとうございます。

>各行に対して、正規表現の文頭を数字で置換しれ

これはよく分かるのですが、

>改行区切りで配列にしてしまうのが簡単だと思う

というのがよくわからないのです。

str="●●●"の●●●の部分に連番を振りたいファイルの内容を
全部コピーして貼り付けて実行すれば良い、ということなのでしょうか?
確かにそれなら実現できました。

ただ、手間がかかるので
連番を振りたいファイルを指定して、
中身を直接書き換えられれば有難いのです。
そのような方法はありませんでしょうか。

ひょっとして初心者丸出しの質問なのかもしれませんが、
御教示頂ければ幸いです。

470:デフォルトの名無しさん
08/12/13 17:46:04
プログラミングとクラスの考え方がまだ身についてないっぽい
必要なのはString オブジェクトだ
つまり文字列

ファイルパスを指定するとファイル内容を文字列で返すメソッドを持つクラスがあるからそれ使え
ファイル内容を文字列で取得できたら文字列内を置換しれ
んで書き込みたい文字列を作れたら、同じ名前でファイルに書き込め

471:デフォルトの名無しさん
08/12/13 18:02:44
・ スクリプト内の変数の文字列を置換する
・ スクリプト内で指定したファイル内容を読み込んで表示してみる
・ 読み込んだファイル内容を置換して表示してみる
・ 置換した内容を別ファイル名で保存してみる
・ あらかじめ元ファイルをバックアップしておき、置換した内容を元と同じ名前で保存してみる
・ あるフォルダ(ディレクトリ)のファイル一覧を取得して表示してみる
・ 自分の欲しいファイル名だけを抽出する方法を考えてみる
・ 一覧のひとつひとつに対してファイル名だけを表示させてみる
・ ファイル名の表示の部分を「ファイル内容を読み込んで表示」に切り替えてみる
・ 「ファイル内容を読み込んで表示」の部分を「読み込んで置換して同名で保存」に置き換える

こんな感じ?

472:デフォルトの名無しさん
08/12/13 18:03:47
> ・ スクリプト内で指定したファイル内容を読み込んで表示してみる
スクリプト内で指定したファイル名の内容を読み込んで表示してみる、だった

473:デフォルトの名無しさん
08/12/13 18:10:45
問題を「これならできそう」って思える程度に分割する能力って大切だよね
オライリーはPragmatic Thinkingなんちゃらって本の日本語版出せばいいのに

474:デフォルトの名無しさん
08/12/13 18:28:21
>>471みたいなのは、現状、意識的に経験積むしかないんだよね
うまい本とかあればいいんだけど、あんまり聞かないな

475:デフォルトの名無しさん
08/12/13 18:33:15
>>471
そんな感じです。お手数をかけてすみません。
それを参考にして一つ一つ覚えて行きたいと思います。

何度か他の言語を覚えようとして挫折したのですが、
Rubyは簡単に結果を出力できて感動したので、
この言語を勉強することにしました。
(プログラムは素人ですが、
 Rubyのコードがシンプルで美しいと思ったのも動機の一つです)

一応「たのしいRuby」と「Rubyレシピブック」は購入しましたので、
今は「15.2 基本的な入出力操作」を試しています。
プログラムとかはやったことはないのですが、頑張って覚えるつもりです。

476:デフォルトの名無しさん
08/12/13 18:37:33
すると

File.open(path, 'r'){|f| puts f.read}

ができた頃かね
f.read が文字列を返してることがわかったら、ファイルひとつを置換するのはもうすぐだな

477:デフォルトの名無しさん
08/12/13 22:18:03
ワンライナーだと
ruby -pe "printf '%4d ',$." ファイル名
でファイルに4桁の行番号をつけて標準出力に表示

ファイルを書き換えたければ -i.bak などと-i オプションにバックアップの拡張子をつけて実行
ruby -i.bak -pe "printf '%4d ',$." ファイル名

標準入力から読み込んだ場合の行番号は$.に入ってる、行番号の形式を変えたければprintfを勉強する
複数のファイルを指定しても大丈夫

Windowsだと -i の拡張子無しでの直接書き換えが出来ないのがちょっとやだな
UNIXだと ファイル開いておいて、開いたファイルを削除して、書き込み用で同名のファイルを作成するのかな?
PerlでもWindowsだと出来ないので、同じような動作してるんでしょうね
というか、Perlの動作を再現してるんでしょうけど


478:デフォルトの名無しさん
08/12/13 22:25:44
path = 'test.txt' #適当に作っといてね
outfile = 'testwrite.txt' #問答無用で上書きされるぞ
と、すると
pathファイルを開いて、全体を一気に読み込んだものを表示する
open(path, 'r'){|f| puts f.read}
pathファイルを開いて、一行読み込んで表示するのを最後まで繰り返す
open(path, 'r'){|f| f.each{|line| puts line}}
pathファイルを開いて、一行読み込んで、行番号表示して、行の内容を表示するのを最後まで繰り返す
open(path, 'r'){|f| f.each_with_index{|line,ind| printf '%3d ',ind+1;puts line}}
pathファイルを開いて、書き込み用のoutfileファイルも開いて、一行読み込んで、ファイルに行番号書き込んでから行の内容も書き込むのを最後まで繰り返す
open(path, 'r'){|f| open(outfile,'w'){|out| f.each_with_index{|line,ind| out.printf '%3d ',ind+1;out.puts line}}}


479:デフォルトの名無しさん
08/12/13 22:30:00
cat -n

480:デフォルトの名無しさん
08/12/13 22:32:30
>>479
そんなこと言ったら行番号付加ツールインストールすれば一発だぞ

481:デフォルトの名無しさん
08/12/13 23:42:38
$.


482:デフォルトの名無しさん
08/12/14 01:44:40
>>476
お恥ずかしながら io.readlines のことかと思って悪戦苦闘していました。
例文通りに打ち込んでも上手く行かないので、何かプログラムの根本的な
ところが判ってないのだと思って再び悩んでいました。

>>477
>>478
ありがとうございます。おかげさまで希望通りの動作が実現しました。
教えて君のような私にここまでして頂いて何と感謝すれば良いのか判りません。
私に何ができるわけでもありませんが、似たようなことがあったら、
私もこのスレの皆さんのような態度で困った人に接したいと思います。
このスレの皆様に心から感謝します。本当にありがとうございました。

483:デフォルトの名無しさん
08/12/14 03:03:55
馬鹿なの?
死ぬの?

484:デフォルトの名無しさん
08/12/14 05:12:40
>>482
たかが2chでそこまでバカ丁寧になる必要はない
教えてやりたい人間が教えたいように教えただけ

>>483
バカ丁寧だから、バカなんじゃない?

485:デフォルトの名無しさん
08/12/14 05:13:18
ああ忘れてた、>>477-478, 乙であります

486:デフォルトの名無しさん
08/12/14 05:40:39
>>484
たかが2chで「必要がない」ことをそんな大きく見てもしょうがない。
他の多くのレスの不必要な表現と同じように、>>482も書きたいように書いただけ。

487:デフォルトの名無しさん
08/12/14 12:37:57
>>455
ないみたいね
そもそもPlaggerのスレさえも立ってない
(理由は不明だけど、俺は人気がないんだと思っている)

話したいなら、ここや本スレでも良いと思うよ

488:デフォルトの名無しさん
08/12/14 12:47:00
ruby-ldapのインストール方法について質問です。
OSはcentos5.2を使用して
ruby本体は、 ruby-1.8.6-p287をcheckinstallにてRPM化しインストールしています。
ruby-ldap-0.9.7-1.i386.rpmを入手して、インストールを試みたところ下記のような
エラーメッセージが出力されて、二日ほど止まりっぱなしです。
どなたかアドバイスをお願いします。

# rpm -ivh ./ruby-ldap-0.9.7-1.i386.rpm
警告: ./ruby-ldap-0.9.7-1.i386.rpm: ヘッダ V3 DSA signature: NOKEY, key ID bfbaf0e8
エラー: 依存性の欠如:
libcrypto.so.5 は ruby-ldap-0.9.7-1.i386 に必要とされています
libruby.so.1.8 は ruby-ldap-0.9.7-1.i386 に必要とされています
libssl.so.5 は ruby-ldap-0.9.7-1.i386 に必要とされています
#


489:デフォルトの名無しさん
08/12/14 13:03:15
>>488
ruby-dev のようなもの、libopenssl-ruby のようなもの、openssl のようなもの、のインストールが足りない
Ruby関係ないな

490:デフォルトの名無しさん
08/12/14 13:13:04
rpm コマンドの使い方の話だね
必要なファイルを含むパッケージを表示する方法があるはずだから、それでインストールするパッケージを調べるといい

491:デフォルトの名無しさん
08/12/14 13:49:11
>>489-490
ruby-devとlibopenssl-rubyについては入っていません。。
ruby-dev`については、自ら作成したrubyのRPMファイルを入れるときに
アンインストールしちゃいました。
含んでいそうなファイルを探してみます。
ありがとうございました。

492:デフォルトの名無しさん
08/12/14 13:53:01
devは作るときのだから、バイナリを入れるだけならなくても大丈夫だと思う。


493:デフォルトの名無しさん
08/12/14 14:51:23
結局、
# rpm -qa | grep ruby
ruby-irb-1.8.6.287-1.el5.kb.1
ruby-libs-1.8.6.287-1.el5.kb.1
ruby-1.8.6.287-1.el5.kb.1
ruby-devel-1.8.6.287-1.el5.kb.1
こんな感じに拾ってきたrpmを入れてから、
#rpmbuild -ta ruby-ldap-0.9.7.tar.gz
を実行して、自分でrpmファイルを作ったら、インストールできました。

この状態だとgemが入れられなかったので、rubyのrpmファイルを自前で作成して
インストール後、上記の状態にしたのでgemがどっかで不具合を起こさないか不安ですけど。
ちなみに、gemがインストールできないのはrdocがロードできないとか怒られた。
rdocのrpmファイルってどこかに落ちてるんでしょうか?

494:デフォルトの名無しさん
08/12/14 14:56:39
ディストリビューションオフィシャルリポジトリの存在を無視するな

495:デフォルトの名無しさん
08/12/14 20:54:03
関連付けでファイルを開きたいのですが、
どうすればいいでしょうか。

 path ="test.txt"
 system("start path")

これだとコマンドプロンプトが立ち上がるだけで
関連付けでファイルを開いてくれません。

496:デフォルトの名無しさん
08/12/14 21:01:50
コマンドラインから「start path」という9文字を入力してEnterしてみ
それと同じことが起きてるだけ

497:デフォルトの名無しさん
08/12/14 21:03:03
system("start #{path}")

498:デフォルトの名無しさん
08/12/14 21:43:35
>>497
出来ました! ありがとうございます。 m(_ _)m

499:デフォルトの名無しさん
08/12/14 22:13:54
あと10日で1.9正式リリースなわけだが大丈夫なの?
1.9向けにライブラリ作っていい?

500:デフォルトの名無しさん
08/12/14 22:26:51










るなら作ってみな

という感じだ
特にEncode関連

501:デフォルトの名無しさん
08/12/14 22:29:24
文法エラーが出なくなる程度の対応は進めてもらえると
いちユーザーとしてもいきなり挫折しなくて済んでいいかも

ruby1.9 ./hoge.rb

しただけで普段見たことも無いファイルのやたら多い行数のとこでSyntaxErroroとか挫けるし

502:デフォルトの名無しさん
08/12/14 22:30:51
>>499
1月に延期されたとかなんとか

503:デフォルトの名無しさん
08/12/14 22:32:38
1.9に自作ライブラリを対応させるためのHOWTOとかそういう文書ってある?
1.9.0 features を読んで逐一チェックするしかない?

504:デフォルトの名無しさん
08/12/14 22:51:10
>>499
12月25日に予定されてるのは、1.9.1のRC(リリース候補)で正式版じゃない
といっても、現時点でもう1.9.1の仕様は固まってるはずなので、今から作り始めても良いと思うが

505:デフォルトの名無しさん
08/12/14 22:51:59
>>503
たぶんrubikitichがホッテントリ狙って書くよ。

506:デフォルトの名無しさん
08/12/14 22:58:22
ぬう

507:デフォルトの名無しさん
08/12/14 23:10:00
下の文字列がなぜ文字化けするのですが、何が原因でしょうか。

$KCODE="s"
tut = "12月28日 夢見師(プリンセスソフト、7,140円) "
p tut

508:デフォルトの名無しさん
08/12/14 23:13:46
s?

509:デフォルトの名無しさん
08/12/14 23:14:57
すいません、

#!/usr/local/bin/ruby -Ks
の1行入れてなかったことによるものでした。お騒がせしてすいません。
>>508
sjisのことです。

510:デフォルトの名無しさん
08/12/14 23:49:31
やっぱり詰まった...。
以下a1の文字列の内()とその中身を消したいのですが、
なぜか ) だけ残して全て消えてしまいます。

#!/usr/local/bin/ruby -Ks
$KCODE="s"
a1="最強 東大将棋6(毎日コミュニケーションズ、2,940円) "
a1 = a1.gsub(/.*?月.*?日 /,"")
a1 = a1.gsub(/(.*?円)/,"")
p a1

511:デフォルトの名無しさん
08/12/14 23:53:36
正規表現中のカッコは特別な意味を持つメタ文字だよ
正規表現中でカッコそのものを表すなら \( や \) のようにエスケープしなきゃだめ

512:デフォルトの名無しさん
08/12/15 01:03:05
>>511
え゛っ、そうなんですか!!
/に\/しなきゃならないのは知っていたですが、()もでしたか。
他でもポカしてそうだな。
ご解答ありがとうございます。

513:デフォルトの名無しさん
08/12/15 01:04:30
>512
英数はそのまま書くとその文字、\を付けると特別な意味になることが多い。
逆に記号はそのまま書くと特別な意味があることが多く、\を付けるとその文字ってことが多い。

514:デフォルトの名無しさん
08/12/15 01:41:29
てかマニュアルに全部書いてあるんだからきちんと読め
記号の意味そのものは必要なときに調べればいいから覚えなくてよし
エスケープが必要な文字かどうかだけを記憶すればおk

515:デフォルトの名無しさん
08/12/15 09:11:03
ピリオドも意味もってるんだけど
間違ってエスケープせずにピリオド使ってても
そのまま動いてしまって気付かないことが多い

あとで忘れた頃に問題が表面化するから初心者は注意な

516:デフォルトの名無しさん
08/12/15 09:54:50
image_paths = filepaths.find_all{|e| /.jpg\Z/ =~ e}

で99.99%くらいは普通に動作するんだよな

517:デフォルトの名無しさん
08/12/15 10:02:26
正規表現の粒度をどれくらいにするかというのは永遠の問題
わかってない人が「メールアドレスにヒットする正規表現を書け」とか課題出したりするんだが

518:デフォルトの名無しさん
08/12/15 10:27:14
"(a)"
から
/\s*\(a\)\s*/
を生成するのってどうやるんですか?
a = "(a)"
/\s*#{a.escape}\s*/
みたいに書ければいいんだけど

519:デフォルトの名無しさん
08/12/15 10:41:09
>>518
マニュアル読んどけ
Rubyの正規表現はただのオブジェクトだからRegexpクラスのメソッドで生成できる
/〜/ で書くのはただのわかりやすいエイリアスに過ぎない

あと、半角スペースと \s には直接の関係はないから、あらかじめ \s で書いておくしかないよ
個人的には半角スペースを \s で表現するようにするのは後々罠に落ちるから全くお勧めしない
半角スペースがあるのなら、どんなに正規表現の見かけがマヌケになっても半角スペースで書くべき

520:デフォルトの名無しさん
08/12/15 11:10:37
>>518
/\s*#{Regexp.escape(a)}\s*/
Regexp.quoteという別名も。

521:455
08/12/15 21:43:26
>>487
あんちゃん、ありがとう。
せつこ、このスレで日本一のpragger目指すんよ。

522:デフォルトの名無しさん
08/12/15 21:57:53
技術的には便利だけど、他のことで代替できるよね、という微妙な立ち位置がどうにも…
プラガブルであることのメリットがイマイチ生かされてないんだな

523:デフォルトの名無しさん
08/12/16 05:42:09
URLリンク(www.google.co.jp)

逆転しそう

524:デフォルトの名無しさん
08/12/16 05:46:15
URLリンク(www.tiobe.com)

逆転もなにも、世界的には10位以下に後退したダメダメ言語だけどね
(ただ、Pythonが下がってたりLogoが爆上げしてるところから見ても
かなり変な順位づけであることは間違いない)

525:デフォルトの名無しさん
08/12/16 19:07:50
D:/desktop にある、

 001test.txt
 002test.txt
 003test.txt

という複数のファイルを、
数字の部分に正規表現を使ったパスで一度に開きたいのですが、
どうすれば良いでしょうか?
次のように書いているのですが上手く行きません。

files = /D:/desktop/[0-9]+test.txt/
 system("start #{files}")


526:デフォルトの名無しさん
08/12/16 19:21:31
リファレンスマニュアルの正規表現のとこ読め
あと %r の使い方も調べとけ

527:デフォルトの名無しさん
08/12/16 19:24:19
よく見たら正規表現関係無いじゃないか
Dir.glob

528:デフォルトの名無しさん
08/12/16 21:05:12
>>527
御返事ありがとうございます。
それで調べたら Dir.glob は正規表現ではなくワイルドカード対応と書いてあるのですが、
これは正規表現には対応していないということではないでしょうか。

>>525の書き込みはあくまで勉強中の実験のものなので、
実際に使う時にはパスを正規表現で指定したいのです。

また、>>525では省略しましたが、
開きたいファイルは似たような名前が多いので、最終的には、

name = ●●
files = %r("D:/desktop/[-9]+●●.txt")
 system("start #{files}")

というような形にして、●●の部分を書き換えるだけで
任意のの複数のファイルを開けるようにしたいのです。

529:デフォルトの名無しさん
08/12/16 21:28:50
>>528
そういうのだと全ファイル名から正規表現でselectせざるをえないかな。


530:デフォルトの名無しさん
08/12/16 21:50:09
Rubyではselectはあまり使わない
find_all と呼ぶ

531:デフォルトの名無しさん
08/12/16 21:59:18
>>528
まったく同じことを繰り返すことになるが、Rubyのオブジェクトについての考え方学んでくれ
返り値がただの文字列なら、それはただの文字列(String クラスのオブジェクト)で、何か特別なものがあるわけじゃない
Stringクラスのメソッドが完全に全て動作するし、文字列オブジェクトを引数にとるメソッドは全て完全に動作する
メソッドの返り値がどのクラスのオブジェクトなのかということは絶対に意識しないと駄目よ

正規表現を使いたいなら、引数…、まあ、引数の見かけしてないことが多いけど、マッチ試行対象は文字列だ
いちばん単純な状態で必要なのは、ディレクトリ中のファイルを文字列で返すメソッド
その文字列の一群の中から、正規表現にマッチする文字列を探して、その文字列をどうにかすればいい

532:デフォルトの名無しさん
08/12/16 21:59:19
>>530
ソースは?

533:デフォルトの名無しさん
08/12/16 22:43:20
target = 'D:/desktop/*'
filter = /\d+test.txt/
system(Dir.glob(target).select{|i| i =~ filter}.unshift('start').join(' '))

534:デフォルトの名無しさん
08/12/17 00:24:48
>>533
なあ、初心者スレなんだから、もっと分かりやすく書こうぜ

filenames = Dir.glob('D:/desktop/*')
filenames = filenames.grep(/^¥d+test¥.txt$/)
system "start #{filenames.join(' ')}"



535:デフォルトの名無しさん
08/12/17 00:34:21
>>534
改行が存在しない文字列に対して ^ と $ は不適
代わりに \A と \Z を使おう

536:デフォルトの名無しさん
08/12/17 00:43:57
どなたかアドバイスください。ruby1.8.7です。

require 'tk' がうまく いきません。以下のようなメッセージが表示されます。
in `require' : no such file to load --tk (LoadError)

どうすればいいでしょうか?


537:デフォルトの名無しさん
08/12/17 00:46:52
>>536
Tcl/Tkが入ってないんじゃね?

538:デフォルトの名無しさん
08/12/17 00:48:23
>>536
tkライブラリを見つけられなかった。

tkがインストールされない環境(ってなんだろ?)か
$LOAD_PATHがおかしいんじゃない?

539:536
08/12/17 01:02:12
sudo find / -name tk で検索したところ

/usr/local/lib/ruby/1.8/test/unit/ui/tk
/usr/lib/ruby/1.8/test/unit/ui/tk

が見つかったんですけどこれとは違うんでしょうか?
ちなみに echo $LOAD_PATHでは何も表示されませんでした。

540:デフォルトの名無しさん
08/12/17 01:13:10
>>534
質問者の求める「正規表現の使えるglob」が提供されて無いから別解を提示しただけ
分かりにくいってのはわざとそうしてるんだから許してよ

>>539
それ違う
OS何?tcl/tk入ってる?wishコマンド使える?

541:デフォルトの名無しさん
08/12/17 08:10:32
>>535
>改行が存在しない文字列に対して ^ と $ は不適
逆だろ。改行が存在しない文字列だからこそ ^ や $ を使っても構わない。



542:デフォルトの名無しさん
08/12/17 08:13:15
>>540
>分かりにくいってのはわざとそうしてるんだから許してよ
なんでそんなことをするの
分かりやすく書けないのをごまかしてるだけじゃねーのかよ

543:デフォルトの名無しさん
08/12/17 08:22:36
>>541
あまりRubyの正規表現に詳しくない人間が見たら
「ああ^と$は文字列先頭と末尾なんだな。Perlと同じなんだな」とか
勘違いしちゃうよ

544:デフォルトの名無しさん
08/12/17 08:44:02
>>534
>system "start #{filenames.join(' ')}"
system 'start', *filenames
でよくね?

545:デフォルトの名無しさん
08/12/17 10:21:20
>>544
そんなこと言ったら2行目はメソッドチェーンで消えるし、
対象ディレクトリが専用ディレクトリならそもそも Dir.glob のワイルドカードつき文字列でも充分だ

君が *引数 をオボエタテだからだからといってわざわざ難しくする必要はない

546:デフォルトの名無しさん
08/12/17 10:28:48
>>541
目に見えない文字や場所にマッチする正規表現は慎重に使ったほうがええぞ
半角空白にマッチさせるために \s を使ったりしないだろ
それと同じこと

547:デフォルトの名無しさん
08/12/17 10:30:19
>>545
544じゃないけど、一般にsystemの引数は ' ' でjoinするより * で渡すほうが空白を含むファイル名等の問題をより安全に回避できるので、* のほうがお勧めだけどね

548:デフォルトの名無しさん
08/12/17 10:37:16
*の引数展開はマニュアルでも辺鄙なとこにしか書いてないからな
使うなら堂々と初心者向け解説の3ページ目から使いまくるくらいの感じにして欲しいとは思う

549:デフォルトの名無しさん
08/12/17 10:45:05
`
mkdir foo
mkdir bar
`

みたいに途中でシェルスクリプトだらだら書けるようなやり方ってない?
上の書き方だとmkdir fooだけ実行されるっぽい


550:デフォルトの名無しさん
08/12/17 10:49:19
`` はシェルコマンドを実行したいときに使う記法じゃないぞ
返り値が必要なときに使うもんだ
system 使え

551:デフォルトの名無しさん
08/12/17 10:57:56
>>544 >>547
やってみた?

552:デフォルトの名無しさん
08/12/17 11:17:32
534です。
>>547
たいへん参考になりました。
ただ初心者スレで使うには説明が必要ですね。

553:デフォルトの名無しさん
08/12/17 11:21:00
>>550
system "
mkdir foo
mkdir bar
"
でも変わらなかった

554:デフォルトの名無しさん
08/12/17 11:31:24
>>553
シェルスクリプトとみなせる環境であるなら全部実行できるはず
動作しないとしたらWindowsかCygwinだな

555:デフォルトの名無しさん
08/12/17 11:33:20
渡した文字列がshに渡るんだから
mkdir foo; mkdir bar だろう。

つーかそんなことしなくても、
mkdir foo bar でいいだろう。

556:デフォルトの名無しさん
08/12/17 11:35:50
>>555
最新5レスしか読めない携帯からのご参加ですか?

557:デフォルトの名無しさん
08/12/17 11:38:56
>>555
mkdir したいって話じゃねーだろ

>>553
Windowsではでっかいひとつのスクリプトとして実行するしかなさそうだな

558:デフォルトの名無しさん
08/12/17 11:39:43
つーか、全部シェルスクリプトで書けば?
system "foo.sh"
したらいいやん

559:540
08/12/17 12:15:12
>>542
初心者にはメソッドチェーンが読みにくいかもしれない、とは思ったけど
読み解くのも勉強になるだろうと思ってそのまま書いた
grep と system(*args) は知らなかったから書き直すよ

target = 'D:/desktop/*'
filter = /\d+test.txt/
command = 'start'
system(*Dir.glob(target).grep(filter).unshift(command))

560:デフォルトの名無しさん
08/12/17 14:15:15
>>559
>system(*Dir.glob(target).grep(filter).unshift(command))
なぜわざわざunshiftを使うのか分からん。>>544の通りに
system command, *Dir.glob(target).grep(filter)
でええやん。

561:デフォルトの名無しさん
08/12/17 14:34:26
すっごい前に、配列からの抽出にpopとshiftを使う子がスレにいたな
キューじゃないものに pop とか使ったらダメよ混乱するから

562:デフォルトの名無しさん
08/12/17 15:00:35
>>530
RubyのselectはSQLのselectじゃなくて
Smallltalkのselectに由来するって知ってるか?


563:デフォルトの名無しさん
08/12/17 15:09:54
>>561
普通に使ってるし、混乱するって話もあまり聞かないぞ
そもそもpopやshiftを使わないとすると、代わりにどんな風に書くんだ?

564:デフォルトの名無しさん
08/12/17 15:14:58
>>562
「外来語」の detect と select で悩むくらいなら find と find_all を使うなあ、俺は
というかなんでそこで SQL が出てくるんだ?

565:デフォルトの名無しさん
08/12/17 15:21:17
当時の様子は知らないし、同じくキューでない配列にも普通にpop/shiftは使うけど
配列から取り除くことが作用ではなく副作用になる場合以外、
「配列から取り除く(ついでに値を得る)」ではなく
「値を得る(ついでに取り除く)」だと思ってるとミスするという話かと。

def get_first(ary)
 ary.shift
end
ary = [1,2,3]
put get_first(ary) # aryが破壊される


566:デフォルトの名無しさん
08/12/17 15:35:31
>>563
同意
queue じゃなくても、popもshiftも使うよな

567:デフォルトの名無しさん
08/12/17 15:38:04
キューでもないのにpopが積極的に必要になる場面が思いつかない
イテレータ拒絶派か何かか?

568:デフォルトの名無しさん
08/12/17 15:42:26
>>567
split結果の先端や終端にゴミついてるのが確実なときに切り落とすためとか。

569:デフォルトの名無しさん
08/12/17 15:55:45
>>568
delete_at(0)


配列先頭のデータが欲しいときに

data = arr.delete(0)

と書くのが奇妙なのと同程度には

# 先頭は不要
arr.shift

と書くのは奇妙だと思う
shift に関してはコマンドライン引数を順に扱うときに shift コマンドを使った経験が後を引いてるのかもしれないが、
ここは Ruby だし shift は変

570:デフォルトの名無しさん
08/12/17 15:57:55
そろそろ誰の何の質問の答えているのかはっきりさせようか

571:デフォルトの名無しさん
08/12/17 15:58:58
じゃあどう書けばRuby的なの?

572:デフォルトの名無しさん
08/12/17 16:19:46
配列を破壊しなければうまくいかないかどうかによって違うんじゃね

573:デフォルトの名無しさん
08/12/17 16:19:54
>>570
>質問・要望・雑談などどうぞ。

>>569
奇妙なのはそのコメント文だろうw
代入操作がないことから不要なことは自明。
返値があるものは代入しないといけないなんてルールはないし。

>>565のように先頭や末尾の要素を配列から取り除くのが主の操作で、
popやshiftにそれ以上の意味(=キュー専用)はないと考えてる。
だからdelete_at使えというのは、firstやlastもat(0)やat(-1)にしろと
言っているように聞こえる。

キューでない配列に対してpopやshiftがよろしくないなら
Array#pop #shift #push #unshiftは廃止してQueueクラスを用意するべき。
運用で制限しようとするほうがおかしい。
(threadのものと名前がかぶるけどそれはさておき)


574:デフォルトの名無しさん
08/12/17 19:49:45
難しく考えたことねえな

ところでその考え方だとpopはキューに使っちゃダメだろ
あれはスタックに使うものでは?

575:デフォルトの名無しさん
08/12/17 21:13:20
>>569
切り捨てるより、shiftで切り出された結果を使う方が多い

param = ARGV.shift
line = lines.shift

とか

576:デフォルトの名無しさん
08/12/17 21:39:05
each でブン回すのが Ruby 的ではあるんだろうな

577:デフォルトの名無しさん
08/12/17 21:54:01
>>574
push⇔shift
unshift⇔pop
これでキューが出来上がる。ただし左がエンキュー、右がデキュー

578:デフォルトの名無しさん
08/12/17 21:59:30
素直にQueueクラス作れよ、というのは昔から言われてはいたな
というか、説明もないしキューの概念知らない人もそこそこいるのでは

579:デフォルトの名無しさん
08/12/17 22:02:02
unshiftだけ遅いから注意が必要

580:デフォルトの名無しさん
08/12/17 22:26:23
unshift遅くなくね?

581:デフォルトの名無しさん
08/12/17 22:33:43
>>578
自慢だが知らん
popやshiftは配列から1個取る便利メソッドだと思ってる

582:デフォルトの名無しさん
08/12/17 23:47:16
>>531
丁寧な解説をありがとうございます。
Rubyの「オブジェクト指向」という考え方が何となく判って来た気がします。

つまり、文字列などの何らかのデータをオブジェクトとして扱い、
その内容に変更を加えたデータ(や当該コード)もオブジェクトにでき、
更にそのオブジェクトに変更を加えたデータも・・・・・
という事が限りなくできる、ということなんですね。
つまり「全てがオブジェクト」なんですよね?

そして、そのあらゆる段階でのオブジェクト(データ)に自分で名前を付けることによって、
任意の段階でのデータ(オブジェクト)をコードのどこでも簡単に使い回しできるようにしたものが、
Rubyのオブジェクト指向、だと理解しました。

そして、初心者が常に気を付けるべき点は、
データを処理するためのメソッドが「どのオブジェクトを対象としているのか」という点にある、
というのが>>531でのアドバイスの要点だと思いました。

基本的な理解はこれで合っているでしょうか? (^^;)

583:デフォルトの名無しさん
08/12/17 23:53:26
Rubyは肯定(否定)戻り読みには対応していないんでしょうか?
肯定(否定)先読みには対応しているようですが。
使っているエディターがPerl準拠の正規表現なので
今までは戻り読みが使えて便利だったのです。

584:デフォルトの名無しさん
08/12/18 00:02:13
lookbehind は鬼車が要るはず

585:デフォルトの名無しさん
08/12/18 00:29:31
>>580
a = []; 50000.times { a.push(0) }

a = []; 50000.times { a.unshift(0) }
を比べてみな

586:デフォルトの名無しさん
08/12/18 00:33:16
yield

587:デフォルトの名無しさん
08/12/18 00:57:28
>>584
ほほう。こういうものがあるんですね。
次期Rubyに搭載予定だそうで凄そうです。
それで鬼車のホームページには、

>* 5.xはUnicode Property/Scriptを提供
>* 2.xはRuby1.6/1.8組込みライブラリとして動作する。 (2006年末で保守を終了)

と書いてありますが、どちらをインストールしたら良いんでしょうか。
詳しい方がいらっしゃったら御教示願います。

588:デフォルトの名無しさん
08/12/18 08:51:32
>>580 じゃないが、試してみて >>585 の優しさを知った。
50000 は絶妙なとこだな。(celeron 1.3GHz)

589:デフォルトの名無しさん
08/12/18 09:31:25
そんな中古でも売ってないような激遅CPUで話にしゃしゃり出られても困る

590:デフォルトの名無しさん
08/12/18 09:47:36
今の平均的なCPU速度ってどのくらいなのかね
自分でちょっと重い処理するライブラリとか公開したときちょっと気になる

591:デフォルトの名無しさん
08/12/18 09:51:40
>>589
Core2Duoでも相当差が付くぞ

592:デフォルトの名無しさん
08/12/18 09:59:23
>>589
そのご立派なCPUで500000とか試してみなよ。

593:デフォルトの名無しさん
08/12/18 10:05:52
噛み付かれた>>588カワイソス

594:デフォルトの名無しさん
08/12/18 10:09:49
>>590
2GHzくらいじゃね

595:デフォルトの名無しさん
08/12/18 10:17:43
てかPentium4からこっちはよくわからん理由で処理速度が違うから周波数アテにならん

596:デフォルトの名無しさん
08/12/18 11:26:59
公開するライブラリの重さなんて気にしなくてもいいんでは?
使う人次第で負荷なんて桁で変わるんだし。

軽く使えるノウハウでもついでに書いとけば喜ばれると思うけど。

597:デフォルトの名無しさん
08/12/18 12:02:34
RubyのArrayはリストとかじゃなくてまんま配列なので、
pushと違ってunshiftは必ずメモリのコピーが発生するから
ってことかな>速度差

598:デフォルトの名無しさん
08/12/18 12:34:38
IronRubyって終わったんでしょうか?

599:デフォルトの名無しさん
08/12/18 15:12:50
>>587
どちらもインストールしないでrubyの1.9.1をインストールする。
まだリリースされてないけど。

600:デフォルトの名無しさん
08/12/18 15:13:58
>>598
終わったというか、まだ始まってない。
そもそもIronRubyの動作基盤であるDLRがまだリリースされてないし。

601:デフォルトの名無しさん
08/12/18 15:19:49
Ruby で「静的 HTML に変換して出力してくれる入力テンプレシステム」って何がありますか?
* で始めると見出しとか、 - で始めるとリストとか、そういうので適当な日記的 HTML を楽に書きたいです
日記や Wiki みたいな動的機能はいらないです
サーバにアップロードするときに Ruby スクリプトで変換して FTP するとか、そんな感じなんですが

602:デフォルトの名無しさん
08/12/18 15:36:51
RD

は死んでる?
gem でイイのないもんかね

603:デフォルトの名無しさん
08/12/18 15:41:45
Hiki に Wiki 書法用のパーサが付いてたような気が

604:デフォルトの名無しさん
08/12/18 15:42:53
WikiCreoleパーサをさがしてみるといいんじゃないか?
あるかどうか知らんけど。

605:デフォルトの名無しさん
08/12/18 15:48:25
RedCloth とか BlueCloth とか。
日本語がちゃんと扱えるかどうかは知らないけど。

606:デフォルトの名無しさん
08/12/18 16:08:25
つWikiforme
使いやすいとは言えないがかなり面白い。
これとTenjin組み合わせれば・・・とか妄想してる。

607:デフォルトの名無しさん
08/12/18 16:09:43
rake で sh "command" としたときに、command が画面に表示されないんですが、そんなものでしょうか。
どんなコマンドが実行されているか表示されてほしいんですけど。

608:デフォルトの名無しさん
08/12/18 17:18:08
Installing ri documentation
Installing rdoc documentation

これでバカみたいに遅いのはなぜ?
中で何やってこんなに遅いの?

609:デフォルトの名無しさん
08/12/18 17:21:52
ソースコードを解析してドキュメントを作ってるから、だと思う。多分

610:デフォルトの名無しさん
08/12/18 17:29:06
ファイルが細かくて多いと死ヌほど時間かかる印象

611:デフォルトの名無しさん
08/12/18 17:30:06
あれってなんで事前作成してないんだろ。
環境によって出力結果変わったりするもの?

612:デフォルトの名無しさん
08/12/18 17:31:55
>>611
できるものがでかいから。

613:デフォルトの名無しさん
08/12/18 17:35:48
まあつまりファイルサイズをケチってるわけだな
実際のドキュメントを見るとわかるがまあ結構デカい

デフォルトデザインのドキュメントくらい添付してもいいと思うんだが、
まあ、全パッケージの全バージョンを保持してるわけだし、
それぞれに2種類のドキュメントをさらに保持というのは確かに辛いかもしれず

614:デフォルトの名無しさん
08/12/18 17:53:36
回答サンクス。でも所詮は圧縮効率よさげなテキストでしょ。
パッケージはgzipとかしてるだろうし、試しにzipアーカイブに・・・

rubygems-1.3.1/rdoc/ 2,425,167byte -> zipped 820,211byte

把握したw

615:デフォルトの名無しさん
08/12/18 18:16:02
余裕じゃん

616:デフォルトの名無しさん
08/12/18 18:45:30
>>603
HikiDocか。

>>601
Hikiのは古いから、HikiDocでぐぐって(単体で保守されてる)
あとはRakeと連携して細かいところを自分で書けばおっけーじゃね。

617:デフォルトの名無しさん
08/12/18 19:17:03
>>601
Marukuもあるよ
高機能な割に、いまいち安定しないが

618:デフォルトの名無しさん
08/12/18 19:26:32
>>611
>あれってなんで事前作成してないんだろ。
事前に作成できるよう指定できるよ。
ようは各gem作者がそれを指定してないだけ。

619:デフォルトの名無しさん
08/12/18 20:10:37
>>599
鬼車のを今の1.86で組み込んで使うことはできないんでしょうか?
戻り読みの正規表現が使えないと非常に困るのです。

ネットで調べたら「VC++で鬼車をコンパイル云々」と出て来ましたが、
プログラミングはRubyから始めたばかりなので、
別のプログラムが必要とかになるとお手上げなのです。

何とかならないものでしょうか。鬼車の2.x系で構わないので。

620:デフォルトの名無しさん
08/12/18 20:18:19
鬼車を使うか旧来のregexエンジンを使うかはコンパイルオプションで
決まっちゃうので、自分でコンパイルがお手上げなら、鬼車を有効に
してあるバイナリを探すしかない。あるかどうか知らないけど。

駄目ならRubyでやるのを諦めるしかないと思うけど。

621:デフォルトの名無しさん
08/12/18 21:13:29
鬼車gemもあるな。
リテラルの/.../だと組込の正規表現クラスを使ってしまうので、
全部明示的にメソッド呼んで組み立てる必要があるが。


622:デフォルトの名無しさん
08/12/18 21:29:29
gem のライブラリのファイルをどこで誰が読んでるかを調べる方法はある?

gem 'package_name', '=1.0.0'

でバージョンを指定してるはずなんだけど、

/usr/lib/ruby/1.8/rubygems.rb:142:in `activate':
can't activate package_name (>= 1.0.1, runtime),
already activated package_name-1.0.0 (Gem::Exception)

という例外が出て動作しない
1.0.0 を指定してるんだから 1.0.0 だけ読んでくれよ
っていうかバージョン指定でインストールさせるライブラリの作者は安易に require だけすんな氏ね

623:デフォルトの名無しさん
08/12/18 21:32:02
>>620
レスありがとうございます。
戻り読みが使えないのは大変に困るので、
素人でもコンパイルと言うものができるなら挑戦してみようと思います。

ええと、ネットで調べたのですが、
Rubyと鬼車のソースを手に入れて解凍し、
鬼車の解凍フォルダをRubyの解凍フォルダに入れて、
Visual C++ Toolkit 2003 Commandでコマンドを入力してコンパイル

で、基本的な流れは良いんでしょうか。
鬼車を組み込むために特別なことは必要ないのでしょうか?

>>621
できれば他の正規表現と全く変わらないように使いたいので、
鬼車を組み込んだRubyの方がありがたいのです。

624:デフォルトの名無しさん
08/12/18 21:39:26
>>623
なんかすごいことしようとしてるなー

ちなみに、その戻り読みが必要な正規表現ってどんなの?
もしかしたら、戻り読みが必要ないかたちに書き換えられるかもしれないし。

625:デフォルトの名無しさん
08/12/18 22:13:45
>>624
> なんかすごいことしようとしてるなー

そんなに素人には敷居が高いのでしょうか?
確かに戻り読みは全ての正規表現に使うわけではないので、
>>621さんの鬼車gemというのを使った方が良いのでしょうか。

626:デフォルトの名無しさん
08/12/18 22:17:53
たぶん、
Object.const_set('Regexp', ORegexp)とかしてしまえば(警告出る)、
Regexp.newで作った後は同じように使える(と思う)から、
/.../と書けない以外はそれなりに使えるんじゃないだろうか。


627:デフォルトの名無しさん
08/12/18 22:18:01
コンパイルとか一回やっとくと後々役に立つこともあるだろうから
やっといてもいいと思うけど。
Cygwinじゃダメなの?

628:デフォルトの名無しさん
08/12/18 22:58:02
>>607
-v

629:デフォルトの名無しさん
08/12/18 23:06:19
>>623
「鬼車を組み込むために特別なこと」は鬼車のドキュメントに書いてある。
それに従えば大丈夫だと思うよ。

630:デフォルトの名無しさん
08/12/18 23:48:15
「ひらがな ←→ カタカナ」の変換ってどうやるんでしたっけ。

631:デフォルトの名無しさん
08/12/18 23:56:38
>>630
Ruby単体では難しいな
NKFに頼るのが妥当か

632:デフォルトの名無しさん
08/12/19 00:01:56
プログラムのlogを自分宛にメールで送りたいと思ったんだがpop before smtpってよくわからん
○行処理完了,×行目失敗,△行目失敗...ぐらいのちょっとしたものなのに

633:デフォルトの名無しさん
08/12/19 00:05:43
>>632
そのまんまだよ
smtpの前にpopでただアクセスすればいい
履歴はサーバが短時間記憶してくれているから普通にsmtpでアクセスだ

メール関連は詳しく説明するとSPAM送るアホが出るからどこも親切にはしてくれないだろうね

634:デフォルトの名無しさん
08/12/19 00:15:20
>>631
サンクス

635:デフォルトの名無しさん
08/12/19 00:51:58
>>630-631
一方向の変換ならString#trじゃダメ?

636:デフォルトの名無しさん
08/12/19 09:48:35
aという配列の要素に、正規表現でキャプチャした値を入れたいです。
具体的には
a[0]=$1
a[1]=$2
以下同様です。
これを
0.upto(4) do i
 a[i]=$(j+1)
end
とかやってもコンパイルエラーがでてしまうのですが、組み込み変数$1,$2・・・に
イテレータを利用してアクセスできる方法はありますか?

637:636
08/12/19 09:49:51
>>636は書き間違いました。
a[i]=$(i+1)
です。

638:636
08/12/19 09:54:02
自己解決しました。
0.upto(4) do i
 a[i]=$~[j+1]
end
でいけました。一人で何やっとるんだ俺は。


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

4283日前に更新/244 KB
担当:undef