Ruby 初心者スレッド Part 18at TECH
Ruby 初心者スレッド Part 18 - 暇つぶし2ch112:デフォルトの名無しさん
08/02/27 19:45:32
def hoge(foo, bar)
 raise ArgumentError unless foo.is_a?(String)
 raise ArgumentError unless foo.is_a?(Array)
 ・
 ・
 ・
end
とかメソッドの最初でモリモリやっちゃうのはだめ?

113:デフォルトの名無しさん
08/02/27 19:58:48
>>112
わりと下品。

まあ、それ以上でもそれ以下でもない程度かと。
コレを無くすために悩む時間がえらい長引くってんならあっても仕方ないんじゃね。おいおい考え変えていけばいいかと。
そのクラスやメソッドに本当にそんなクラスのインスタンスが指定されることがあるのか? をよく考えるといい。
標準添付で「結果の数によってStringあるいはArrayが返ります」とかいうメソッドがあるかい?

…そういえばなんか添付モジュールで複数のクラスが返ってくる可能性のあるやつあった気がするがまあいいや。

「Stringが来たときはHashに変換しよう」とかいうのも同様。Stringなんか渡してくる奴が悪い、で桶。
raaやgemで公開して育てる気マンマンでちまちまフールプルーフさいこー、という場合はあったほうがいいのかも。

114:デフォルトの名無しさん
08/02/27 20:07:48
日本語がよくわからない

115:デフォルトの名無しさん
08/02/27 21:35:03
>>102
require 'stringio'
# 標準出力へのフックを仕込む
$stdout = StringIO.new
# 標準出力に出力
puts '未承諾広告'
puts 'こんにちは^^)'
#
# 標準出力に書き出した内容を
$stdout.rewind
text = $stdout.read
メールで送信(text)

116:デフォルトの名無しさん
08/02/27 21:42:15
>>115
ぬう、適切だが邪悪だ…

117:デフォルトの名無しさん
08/02/27 21:45:13
>>110
eachに反応するときだけeachしたいなら、
respond_to? :each する。

と思ったことが私にもありました。

なんでStringがeach持ってるんだよ……(1.8での話)



118:デフォルトの名無しさん
08/02/27 21:48:51
>>116
標準出力をフックしたいとか言う元の要件自体が邪悪なだけだ(w

使い方自体は巻き戻せるIOの正しい使い方
$stderrに仕込んでおくとwarnの出力をロギングできるぞ
warn使ってる人ってあんまり見ないけどな

>>117
eachの中でArrayやHashという構造べったりの処理をするからあまり意味がなかったり…

119:デフォルトの名無しさん
08/02/27 21:52:27
STDOUTに元の残ってるし、
writeメソッドがないとTypeErrorだし、
邪悪っていうにはおとなしい希ガス。
バッドノウハウなのは確かだけど。

120:デフォルトの名無しさん
08/02/27 23:24:04
>>118
>標準出力をフックしたいとか言う元の要件自体が邪悪なだけだ(w
そんなことないだろ
なんで邪悪なのか説明してみな

121:デフォルトの名無しさん
08/02/28 09:08:29
Herokuってどうよ

122:デフォルトの名無しさん
08/02/28 12:40:13
>>120
出力先が固定になってるあたりかな。


123:デフォルトの名無しさん
08/02/28 13:02:13
なんでパイプしてその先でメールするんだと
駄目なんだろ。

124:デフォルトの名無しさん
08/02/28 13:06:51
>>122
それだけじゃわかんね。固定してたらなぜだめなの?

125:デフォルトの名無しさん
08/02/28 13:16:13
標準出力をフックしたい⇒出力先が固定
意味不明だな。

126:デフォルトの名無しさん
08/02/28 13:20:35
なんかのはずみで標準出力に出るようなものも全部キャプチャしたいなら
すなおに別プロセスで読み出せ

127:デフォルトの名無しさん
08/02/28 14:07:34
こんなもんでいいんじゃね

class Dummy
@@origout = $stdout

def initialize
@buf = ''
end

def write(str)
@@origout.write(str)
@buf << str
end

def flush
tmp = @buf
@buf = ''
tmp
end
end

$stdout = Dummy.new
puts "hello"
puts "world"
$stderr.puts $stdout.flush.inspect

思い切り誤爆してきた。。。


128:デフォルトの名無しさん
08/02/28 15:43:56
>>126
なんで別プロセスにするのがいいの?
$stdout = StringIO .new
だとなんか問題あるの?

129:デフォルトの名無しさん
08/02/28 15:47:47
>>118 バカ
>>122 バカ
>>126 バカ

130:デフォルトの名無しさん
08/02/28 15:53:15
バカとしか言えない>>129はバカでよい
是正させる気も無いようだしただの害悪だな

131:デフォルトの名無しさん
08/02/28 16:52:29
>>128
URLリンク(www.ruby-lang.org)

大抵はそれで問題ないけど
拡張ライブラリとか子プロセスなんかの出力は
$stdoutを書き換えるだけだとリダイレクトできないはず

132:デフォルトの名無しさん
08/02/28 18:41:22
Rubyに限ることではありませんが、
httpでpostするデータが大きくてメモリ不足になるとき
どうやって回避するのがよいのでしょうか?
Net::HTTP.start(host) {|http| r = http.post(path, data, header) }
という感じでpostするときdataが大きすぎる場合に備えて
小出しに分けて送ることってできませんか?


133:デフォルトの名無しさん
08/02/28 19:08:26
>>131
だったら最初からそう書けよ
おまえの書き方だと $stdout を変更するのがすべて悪いみたいじゃないか

>>130
バカはおまえだろ

134:デフォルトの名無しさん
08/02/28 19:13:28
>>132
サーバ側の話? それともクライアント側の話?
サーバ側の話なら、cgi.rbを使わず自前でHTTPを解析する必要がある。
クライアントの話なら、dataをファイルに保存しておいて、例えば10MBずつ読み込んで送信を繰り返せばいいんじゃね?

135:デフォルトの名無しさん
08/02/28 20:13:54
空気悪いな
>>131はこの話題に関しては初めて書きこんだのだが

>>132
クライアント側だとすると、body_streamを使うのはどう?
URLリンク(d.hatena.ne.jp)
この辺か

136:デフォルトの名無しさん
08/02/28 20:34:05
>>133=129
あきらめろ、幾ら頑張ってもお前の>>129は「馬鹿じゃない」と解釈する余地が無い。

137:デフォルトの名無しさん
08/02/29 01:19:04
URLリンク(www.ruby-lang.org)
1.9 featureって書いてあるから1.8じゃ使えないのかと思ったら1.8.6でも使えるのね。よかった。


138:デフォルトの名無しさん
08/02/29 11:22:09
>>134
クライアントです。
分けるといっても複数のpostを一連の1つのpostと
認識させるにはどうしたらいいんでしょうか…

>>135>>137
チャンク形式っていうんでしょうか?
で、body_streamを使えばヘッダとか気にしなくていい
ってことでよいでしょうか?

>>132 のdataの内容を一旦 data.txt に書き出しておいて、
あとは >>135 の例のchunkedを使うようにするとできたっぽいですが、
一時ファイルを使わないようにできないでしょうか?


139:デフォルトの名無しさん
08/02/29 12:48:00
RubyにあるモジュールはCGIやHTTPの知識の必要性を良くも悪くも隠蔽しない
その知識のまま進むのは危険だ
HTTPやCGIの勉強をすることを勧めるよ

140:デフォルトの名無しさん
08/02/29 13:29:26
>>138
>>137が書いてるページの body_stream 使うんだろうけど、おれもやったことないからわからん。
ぐぐったらこんなのあった
URLリンク(d.hatena.ne.jp)

141:デフォルトの名無しさん
08/02/29 14:11:22
curlコマンド使うのが一番楽やねん

142:デフォルトの名無しさん
08/02/29 18:17:48
「年・月・日」ではなく「年・月」の2つしかないデータがあるんだけど、
これを格納するデータオブジェクトって何がいいかな?

いや、年月日が揃ってるデータと「年・月」が同じかどうかという比較をするんよ
年月日ならDateオブジェクトなんだけど、日をどうしようかなあと

143:デフォルトの名無しさん
08/02/29 18:30:19
>>142
 ・ 「どうせ参照されないからいいじゃん?」とか年金式にdayを1に固定してDateを使う
 ・ [year, month] という配列に入れておく
 ・ Dateを継承した「dayが無指定でも動く」という新しいDateを作る

144:デフォルトの名無しさん
08/02/29 21:05:14
・Date に適当にメソッドを足して適当に YYYY/MM/01 でも代表元に使う

145:デフォルトの名無しさん
08/02/29 21:09:37
require 'yaml'

yaml_str = <<YAML_STR
hoge:
- moge: [poge, page]
YAML_STR

data = YAML.load(yaml_str)
data['hoge'].each {|key,value| p key,value}

こうすると、
keyが{"moge"=>["poge", "page"]}
valueがnilになってしまいます。

key=moge,value=[poge, page]
になって欲しいのですが…。
どこが間違っているのでしょうか?

146:デフォルトの名無しさん
08/02/29 21:47:44
data["hoge"] #=> [ {"moge"=>["poge", "page"]} ]
つまり "moge"=>["poge", "page"] という(キーが一つの)ハッシュを一つ持つ配列

mogeをリストにせずにインデントで階層にすれば
data["hoge"] #=> {"moge"=>["poge", "page"]}
になる

147:デフォルトの名無しさん
08/02/29 22:09:30
>>145
data['hoge'].each {|hash| hash.each {|key,val| p key, val}}

148:デフォルトの名無しさん
08/02/29 22:17:20
>>146-147
ありがとうございました
YAMLのマッピングの記述を勘違いしていたようです

149:デフォルトの名無しさん
08/03/01 01:09:51
なんか最近思うんだけどさ
ここ「初心者」スレだよな・・・

素直に本家行けば?って人ばっかりじゃね?

150:デフォルトの名無しさん
08/03/01 04:39:41
本スレはMatzと愉快な仲間たちについて
あれこれ語るスレであって、プログラムを語るスレではないのです


…あれ? じゃあ板違いじゃない?

151:デフォルトの名無しさん
08/03/01 11:36:51
「Rubyの初心者」のスレでしょ?
プログラミング自体の初心者じゃないといけないの?

152:デフォルトの名無しさん
08/03/01 11:44:14
>>149が考えるところの「本スレ」のレベルに依存するな

153:デフォルトの名無しさん
08/03/01 18:15:48
>>149
同意。

154:デフォルトの名無しさん
08/03/01 18:39:06
あんなS/Nの小さいスレ
使ってられねーよ

155:デフォルトの名無しさん
08/03/01 20:00:41
irb> s = '2'; case s; when /(1)/,/(2)/,/(3)/ then p $1 end
"2"

irb> s = '2'; case s; when Regexp.union(/(1)/,/(2)/,/(3)/) then p $1 end
nil

なんで?

156:デフォルトの名無しさん
08/03/01 20:07:39
unionすると
/(1|2|3)/ になるのではなく
/(1)|(2)|(3)/ になって、
今回マッチしたのは(2)のとこだからグループとしては$2。
$1ではない。


157:デフォルトの名無しさん
08/03/01 20:16:53
>>156
をを

…正規表現をコンマで並べても用が済むcaseでunionを使うのはめんどくさいっすな

158:デフォルトの名無しさん
08/03/01 21:37:16
nkf.guessやKconv.guessなんかを文字列にしたいんだけど、
この文字列の配列ってあらかじめ定義されてないんでしょうか?

文字コードの推測
URLリンク(www2u.biglobe.ne.jp)

159:デフォルトの名無しさん
08/03/01 21:54:35
ないっす
いわゆるエンコーディングの名称・略称を表示するようにはできてない

puts "#{str}は日本語EUCだよ!" if NKF.guess(str) == NKF::EUC

というような使い方しか想定してない模様

一応
irb> NKF.constants
["UTF8", "VERSION", "JIS", "UNKNOWN", "NKF_VERSION", "ASCII", "UTF32", "SJIS", "NOCONV", "AUTO", "REVISION", "UTF16", "EUC", "BINARY", "NKF_RELEASE_DATE"]
の結果をどうにかすればできなくはないけど、
自前で文字列対応テーブルを書いたほうがたぶん早い

160:デフォルトの名無しさん
08/03/01 22:05:26
>>159
サンクス >>158のページのようなのを使いまわすことにする

161:デフォルトの名無しさん
08/03/02 00:52:59
net/httpで相手サーバがタイムアウトした場合の例外をキャッチしたいんだけど、
具体的に何の例外が発生するんですか?

というか、そのへんの情報ってどっかにまとまってませんか?

162:デフォルトの名無しさん
08/03/02 00:58:15
手元の俺スクリプトの例

rescue Net::ProtoRetriableError,Net::ProtoFatalError,Net::ProtoServerError,Errno::ETIMEDOUT,TimeoutError =>ex
puts 'サーバーから応答がないので空データを使います'
return ''

正直、ドレが効いてるんだかよくわからん

163:デフォルトの名無しさん
08/03/02 01:04:24
net/protocol.rbを見ると、ソケット生成(接続)や読み書きは
timeoutメソッドの中でやってるのでTimeout::Errorかな。
TimeoutErrorはこれの後方互換用。



164:デフォルトの名無しさん
08/03/02 01:10:11
http.getに該当する部分から飛び出す例外を全部捕捉して
「よくわからんけど鯖がエラー返しましたエラー」にすれば桶

begin
res = open(uri).read
rescue
puts "#{uri.host}のサーバかそこへのアクセスで何かエラーです"
res = ''
end

実際問題としてサーバー側の原因以外の例外はここでは起こらんわけだし
Timeoutだけ補足してもProtoServerErrorの500系エラーはスルーされるぞ
500系エラーって新幹線みたいだな

165:デフォルトの名無しさん
08/03/02 01:15:10
Timeout::ErrorはStandardErrorのサブクラスではないので、
引数なしのrescueでは捕まらんのだわ。


166:デフォルトの名無しさん
08/03/02 01:27:51
>>165
既にFAQレベルだな…
URLリンク(blade.nagaokaut.ac.jp)

直感的という言葉は使いたくないがやっぱ説明なしじゃわかりにくいよね
シグナルとかあのへんの勉強をするといいんだが、ちと重いな

167:デフォルトの名無しさん
08/03/02 01:33:49
Errno::ETIMEDOUT って何?

168:デフォルトの名無しさん
08/03/02 01:39:30
タイムアウトした(Timed Out)というエラー。


169:デフォルトの名無しさん
08/03/02 01:46:43
ネット系はErrno::ECONNABORTEDとかErrno::ECONNRESETみたいなのも飛んでくるし、
例外をキャッチしても、それ以降の接続はなにやっても失敗したりするので悩ましい

170:デフォルトの名無しさん
08/03/02 01:51:49
>>167
システムコールが返すタイムアウト

Timeout::Error → 「相手のWebサーバからHTTPの返事が返ってこない」
Errno::ETIMEOUT → 「Webサーバ以外の色々から返事が来ないタイムアウト」

と思って桶
そもそもサーバが見つからないとかそういうの。たぶん

>>169
retryはたいてい成功しないよね

171:デフォルトの名無しさん
08/03/02 16:23:37

return @hoge = kekka



@hoge = kekka
return kekka



@hoge = kekka
return @hoge

ってどれが一般的かな

172:デフォルトの名無しさん
08/03/02 19:11:27
@hoge = kekka

173:デフォルトの名無しさん
08/03/02 20:47:42
@hoge = kekka
return

174:デフォルトの名無しさん
08/03/02 21:09:01
>>171
returnを使いたくて仕方ないのなら2番目でよろしく
1番目はなんか見てて不安だ

175:デフォルトの名無しさん
08/03/02 21:33:05
win環境で、一番簡単に
ファイルのオープンダイアログを表示するには
どうすればいいでしょうか

もろもろインストールの必要を最小限にしたかったりもします。

176:デフォルトの名無しさん
08/03/02 22:03:12
require 'win32ole'

d = WIN32OLE.new("MSComDlg.CommonDialog")
d.maxFileSize = 256
d.showOpen
p d.fileName

177:デフォルトの名無しさん
08/03/02 22:05:12
楽なのはVisualuRubyかなぁ。通常のrubyには入ってないけど、
Windows用のActiveScriptRubyならデフォで入ってます

require 'vr/vrcontrol'
fn=SWin::CommonDialog::openFilename(nil,[ ["All file","*.*"],["bmp file","*.bmp"] ])
p fn

細かいことはVisualuRubyサイトのドキュメントやサンプル見てください

ActiveScriptRuby
URLリンク(arton.hp.infoseek.co.jp)
VisualuRuby計画(仮称)
URLリンク(www.osk.3web.ne.jp)

178:デフォルトの名無しさん
08/03/02 22:13:20
ファイルロックに関する事なんですが、みなさんはどの様なロジックで組んでますか?
自分は普通に以下みたいな感じなんですが、ごくたまにファイルが壊れる事があるんですよね…
なにか良い方法があればご教示お願いします。

File.open('data.dat', 'r'){|file|
file.flock(File::LOCK_SH)
file.read
}

File.open('data.dat', 'w'){|file|
file.flock(File::LOCK_EX)
file.write(data)
}

179:デフォルトの名無しさん
08/03/02 22:17:53
>>178
スレッド使ってる?

180:デフォルトの名無しさん
08/03/02 22:22:39
>>179
いえ使ってません。

181:デフォルトの名無しさん
08/03/02 22:45:34
書き込みの場合は、アンロックする前に
flushしないと、アンロックした後に書き込みが行われる場合がある
みたいな事を言っている方がいたので、その辺の問題のせいでしょうか…

File.open('data.dat', 'w'){|file|
file.flock(File::LOCK_EX)
file.write(data)
file.flush
file.flock(File::LOCK_UN)
}

とかなのかな??

182:デフォルトの名無しさん
08/03/02 23:51:49
175です。早速にレス感謝です。
>>176を試みてみまして
WIN32OLERuntimeError
に悩まされております・・・

もうちょっとWIN32OLE研究してみます。

183:デフォルトの名無しさん
08/03/03 00:17:15
>>176はOS側の環境依存の度合いが大きいよ
インストールしたRubyの種類に依存する>>177と好きなほう選べ

184:デフォルトの名無しさん
08/03/03 00:52:19
# RDEで以下のようなスクリプトを実行します
puts '文字を打ってくれ'
s = gets
puts s + 'と打ったのだね'
#すると画面左下の実行画面が表示される部分に'文字を打ってくれ'と表示される前に
#文字を入力するように求められます(文字を打たないと'文字を打ってくれ'と出ない)

ヒントだけでいいのでご享受ください。RDEとかいう開発環境なんか捨てた方がいいのでしょうか?

185:デフォルトの名無しさん
08/03/03 00:54:36
getsの前に$stdout.flushしたらうまくいったりする?



186:デフォルトの名無しさん
08/03/03 00:56:47
STDOUT.sync = trueな予感


187:184
08/03/03 01:03:01
STDOUT.sync = true を使うことで
RDEでgetsが実行される前の文字が表示されるようになりました($stdout.flushではだめでした)
ありがとうございました! >>185 >>186

188:デフォルトの名無しさん
08/03/03 06:15:51
>>182
これはどうかな?
tk環境が要るけど。

require "tk"
#rootを非表示にする
root=TkRoot.new.withdraw
types = [
["Ruby" , ".rb"],
["All Files", "*" ]
]
path = Tk::getOpenFile(:filetypes=>types, :defaultextension=>".rb")
p path

189:デフォルトの名無しさん
08/03/03 13:37:22
「あまり別途インストールしたくない」という要求に対してWin32OLEやVisualuRubyが既に出てるのに
わざわざRuby/Tkで同じ標準ファイルオープンダイアログを出す根性に感服した

190:デフォルトの名無しさん
08/03/03 13:43:03
宿題スレとか一部で流行ってるからな >Ruby/tk

191:デフォルトの名無しさん
08/03/03 14:39:30
>>178
flock関数を使わずに、自前でロック処理を作るとか

192:デフォルトの名無しさん
08/03/03 15:07:19
「自前」は迷宮への入り口の罠
何か有るはず。
俺はしらないけど^^;

193:デフォルトの名無しさん
08/03/03 15:44:29
わざわざ関数って言い換えてる奴は同一人物か?

File.flockより堅固なファイルロックを自前で作れる奴なら悩んだりしないだろ
ファイルロックの失敗によってファイルが破損しているのだということを確かめる必要があると思われ

194:デフォルトの名無しさん
08/03/03 17:39:45
>>187
実際の実行では不要なんだけどね
RDEの時だけ必要

195:デフォルトの名無しさん
08/03/03 18:48:29
日本語にマッチする正規表現はどのように書きますか。
文字コードはUTF8またはEUC-JPです。

196:デフォルトの名無しさん
08/03/03 19:56:30
それはあれだ、スクリプトがUTF-8だけどEUC-JPの日本語文字にマッチする正規表現を書きたいとかそういう引っかけ問題か(w

197:デフォルトの名無しさん
08/03/03 20:23:04
Shift_JIS = /\A(?:
[\x00-\x7f\xa1-\xdf] |
[\x81-\x9f\xe0-\xfc][\x40-\x7e\x80-\xfc]
)*\z/nx

EUC_JP = /\A(?:
[\x00-\x7f] |
\x8e [\xa1-\xdf] |
\x8f [\xa1-\xdf] [\xa1-\xdf] |
[\xa1-\xdf] [\xa1-\xdf]
)*\z/nx

UTF8 = /\A(?:
[\x00-\x7f] |
[\xc2-\xdf] [\x80-\xbf] |
\xe0 [\xa0-\xbf] [\x80-\xbf] |
[\xe1-\xef] [\x80-\xbf] [\x80-\xbf] |
\xf0 [\x90-\xbf] [\x80-\xbf] [\x80-\xbf] |
[\xf1-\xf3] [\x80-\xbf] [\x80-\xbf] [\x80-\xbf] |
\xf4 [\x80-\x8f] [\x80-\xbf] [\x80-\xbf]
)*\z/nx


198:デフォルトの名無しさん
08/03/03 21:16:12
ジス イズ ア ペン。

199:デフォルトの名無しさん
08/03/04 01:38:47
>>178
file.flock(File::LOCK_EX) よりも前に、File.open('data.dat','w') の時点でファイルの内容がクリアされてしまっている。

File.open('data.dat', File::WRONLY|File::CREAT) {|file|
file.flock(File::LOCK_EX)
file.truncate(0)
file.write(data)
}

…のようにすればいいんじゃないかな。


200:デフォルトの名無しさん
08/03/04 03:28:37
>>197
Kconv::RegexpEucjp と Kconv::RegexpUtf8 だな
いわゆる全角文字と半角カタカナだけ欲しい場合は [\x00-\x7f] だけの行を消すといい

irb> puts 'aa康1アアア1煕表示字典ねdこd'.scan(/(?:\x8e[\xa1-\xdf]|\x8f[\xa1-\xdf][\xa1-\xfe]|[\xa1-\xdf][\xa1-\xfe])+/n)

アアア
煕表示字典ね



201:178
08/03/04 07:36:00
>>191
File.rename使って色々やってみたんですが
やはり上手く行かなくて…

>>199

> File.open('data.dat','w') の時点でファイルの内容がクリアされてしまっている。
それはそうですね、確かに。

ちなみに、以下のコードみたいにする事で、だいぶ頑丈になりました!

#Read
File.open(path, 'r'){|f|
f.flock(File::LOCK_SH)
data = f.read
}

#Write
File.open(path, File::WRONLY | File::CREAT){|f|
f.flock(File::LOCK_EX)
f.rewind
f.write(data)
f.truncate(f.tell)
}

#Append
File.open(path, 'a'){|f|
f.flock(File::LOCK_EX)
f.seek(0, File::SEEK_END)
f.write(data)
}

202:デフォルトの名無しさん
08/03/04 11:22:04
どうして atomic な方のディレクトリロックを使わないん?

203:ルファー ◆XSlQ/Lfer.
08/03/04 12:48:34
Win32APIライブラリを使い、DLL関数から文字列を取得するにはどうすれば良いんですか?
ツクール(URLリンク(tkool.jp))のRGSS1を使っているので、バージョンアップできないし、
ライブラリはRubyで作らないとrequireできないし・・・。

204:デフォルトの名無しさん
08/03/04 13:07:45
>>203
URLリンク(www.google.com)

205:ルファー ◆XSlQ/Lfer.
08/03/04 13:11:44
>>204
あぁ、解決しました。ありがとうございます。

206:デフォルトの名無しさん
08/03/04 13:14:27
うわあ…

207:デフォルトの名無しさん
08/03/04 13:40:32
1レスで解決したならそれはそれでいいじゃん

208:デフォルトの名無しさん
08/03/04 16:42:14
標準添付のWeb::Agentって使ってる人いる?

209:デフォルトの名無しさん
08/03/04 20:58:32
ruby -v; egrep '¥<Web¥>' **/*(.)
ruby 1.8.6 (2007-09-24 patchlevel 111) [universal-darwin9.0]
webrick/httprequest.rb: # (URLリンク(Web.Golux.Com))
webrick/httpservlet/filehandler.rb: # (Web Distributed Authoring and Versioning)

どこにあるクラス?


210:デフォルトの名無しさん
08/03/04 22:17:54
Noraは標準添付ではない。

211:デフォルトの名無しさん
08/03/06 06:35:30
例えばCで定義された以下の様な構造体があって
その構造体のデータが格納されたデータファイルを
1レコードずつRubyスクリプトで読み込む時に

struct Record{
char n, int a, int b;
};

以下の様な、なんだか非効率な方法しか分かりません…
とりあえず、一括してreadして、あとで上手くunpackで切り分けとか出来ないでしょうか?

File.open('data.dat', 'rb'){|f|
while !f.eof?
n = f.read(1)
a = f.read(4)
b = f.read(4)
data.push(n.unpack('L')[0].to_s + ',' + a.unpack('S')[0].to_s + ',' + b.unpack('L')[0].to_s)
end
}

212:211
08/03/06 06:38:11
× data.push(n.unpack('L')[0].to_s + ',' + a.unpack('S')[0].to_s + ',' + b.unpack('L')[0].to_s)
○ data.push(n.unpack('c')[0].to_s + ',' + a.unpack('i')[0].to_s + ',' + b.unpack('i')[0].to_s)

213:デフォルトの名無しさん
08/03/06 08:08:47
>>211
# char n の後ろに3バイトのパディングがあると仮定して
data << f.read(12).unpack('cxxxii').join(',')

214:211
08/03/06 11:22:00
>>213
あ、レスどうも。

一応以下みたいなコードでだいぶマシになりました。
あとはループ展開するとかで、どうにか納得いく速度が出せそうです。

tmp = ''
data = []
File.open('data.dat', 'rb'){|f| data = f.read }
(tmp.size / 9).times{
(n, a, b) = tmp[p, 9].unpack('LSL')
p += 9
data.push(n + ',' + v + ',' + b)
}

215:211
08/03/06 11:23:35
× (n, a, b) = tmp[p, 9].unpack('LSL')
○ (n, a, b) = tmp[p, 9].unpack('cii')

216:デフォルトの名無しさん
08/03/06 12:37:48
見てるこっちが切なくなるやりとりだな・・・

217:デフォルトの名無しさん
08/03/06 12:51:12
pで表示すると、
"hoge"
とカッコ付きで表示されます。
hoge
とカッコなしで表示するにはどうしたらいいですか?

218:デフォルトの名無しさん
08/03/06 12:54:06
print

219:デフォルトの名無しさん
08/03/06 12:57:41
え?pってprintの略じゃなかったんですか…

220:211
08/03/06 13:15:50
>>216
何かもっと良い方法があればご教示下さい><

221:デフォルトの名無しさん
08/03/06 14:08:49
>>219
そういう解説をしてるサイトか書籍があったら即晒せ

222:211
08/03/07 02:24:18
これ以上良い方法が思いつかない…

data = []
File.open('data.dat', 'rb'){|f|
tmp = f.read
cnt = tmp.size / 9
a = tmp.unpack('cii' * cnt)
cnt.times{|i| data.push([a[3 * i], a[3 * i + 1], a[3 * i + 2]].join(',')) }
}

223:デフォルトの名無しさん
08/03/07 03:07:28
効率といっても速度なのかメモリフットプリントなのかコードサイズなのか
data = f.read.enum_for(:scan, /.{9}/m).map {|x| x.unpack('cii').join(',') }

あと、>>213が書いてるけど、パディングは考慮してある?
処理系によっては#pragma packeとか


224:211
08/03/07 03:39:45
>>223
効率は速度です><

>パディングは考慮してある?
ちょっと説明の仕方が悪かったです…
要するに、[1][4][4] の各バイトのデータの並びという事です(バディングは考慮する必要はないです)

変な説明をしてすみませんでした!><

225:デフォルトの名無しさん
08/03/07 09:55:09
>>217
ダブルクォートをカッコと呼ぶやつは初めて見た。

226:デフォルトの名無しさん
08/03/07 11:30:10
カッコ悪い呼び方だよな

227:デフォルトの名無しさん
08/03/07 15:05:55
審議中AAry

228:デフォルトの名無しさん
08/03/07 15:13:38
Float のメソッドで、
「0 から遠い方に丸める(切上げ)メソッドはありません。」
のはなんでだろう?

truncate (to_i) との対称性から、あってもバチは当たらないと思うんだけど。
やっぱ名前?

229:デフォルトの名無しさん
08/03/07 18:16:19
【審議チュウ】

   (⌒ー⌒) (⌒ー⌒)
(⌒-⌒)´・ω)(・ω・`(⌒ー⌒)
(  ´・ω ー⌒)(⌒ー⌒)ω・` )
| U(  ´・) (・`  ) と ノ
~-u (l    ) (     ノu-u'~
    ~'u-u'  `u-u`~






               _
            /´  `フ
           /      ,!
           レ   _,  r ミ       (⌒ー⌒)
          /  `ミ __,xノ゙、      r(   ´n
.         /        i        >   ,/   (⌒ー⌒)
         ,'    .     ,'     ~'oー、_)     r(   n)
        ;     ',  l  l                `/  <_
        i       |  | |              ~'し -一┘
      ,.-‐!     ミ  i i                     (⌒ー⌒)
     //´``、    ミ  、 ー、                   ( ´・ω)
.    | l    `─-ハ、,,),)'''´                 ~、/  っっ
     ヽ.ー─'´)                   (⌒ー⌒)   └ー-、ぅ
        ̄ ̄                      r、´・ω・))
                  (⌒ー⌒)      >  _/´
        n__n        (´・ω・`)    ~'し-一┘
      (⌒ー⌒)ノ         c'   っ
    c('・ω・`)っ      ~(_,'ーo'

230:デフォルトの名無しさん
08/03/07 18:55:39
なんだかわからんがなごんだ

231:デフォルトの名無しさん
08/03/07 21:00:49
ショッピングカートを作っています。
session["cart"]=Hash.new
session["cart"][@itemid]=@amount
のような形でsession["cart"]にハッシュを詰め込みたいのですが、
sessionにハッシュを詰め込むことは無理なのでしょうか?
また、無理であればto_aで配列に変換して詰め込もうと思うのですが、
元に戻すとき、
@tempSession=Hash[*session["cart"].flatten]
と、WEBの公式マニュアル(ハッシュの項)にあるようにやっても
うまくいきません…。
どなたかご教授いただければ幸いです。

232:デフォルトの名無しさん
08/03/07 21:03:38
なお、使っている鯖はlolipopで、Rubyバージョンは1.8.2です。
よろしくお願いいたします。

233:デフォルトの名無しさん
08/03/08 11:53:03
>>231
デフォルトだと文字列しか格納できない。
任意のオブジェクトを格納するには CGI::Session::PStore を使う。
require 'cgi/sesion/pstore'
session = CGI::Session.new(cgi, 'database_manager'=>CGI::Session::PStore)
session[key] = Hash.new

234:231-232
08/03/08 12:52:26
>>233さん
書き込み後、文字列→配列へ変換→処理→文字列へ返還でできましたが、
やはりコードが汚くなったので悩んでいました。
PStoreについて勉強してみようと思います。
これで悩みが解決しそうです。ありがとうございました!

235:デフォルトの名無しさん
08/03/08 14:00:53
>>234
JSON や YAML の文字列に変換するという手もある。

236:デフォルトの名無しさん
08/03/08 14:16:02
「文字列→配列へ変換→処理→文字列」と似たようなシロモノ紹介してどうする

237:デフォルトの名無しさん
08/03/08 15:27:12
はあ?YAMLやJSON使うなら手軽だしコードが汚くなることもないじゃん。
ちゃんとメリットあるものを紹介してなにが悪いの?

238:デフォルトの名無しさん
08/03/08 15:36:34
net/httpについての質問です。
対象ページの[keywords][description]を取得したいのですが
http.getで返ったボディを正規表現で抜き出す以外によい方法はないでしょうか?
宜しくお願いします。

239:デフォルトの名無しさん
08/03/08 15:43:58
>>237
236じゃないが、
突っ込む前と取り出した後に処理がいらうってとこの
面倒くささは大して変わらないじゃん。
CGI::Session::YAMLStoreとかをこさえて使うなら
アリだろうけど。

240:デフォルトの名無しさん
08/03/08 16:06:45
>>238
[keywords][description] というのが何を指してるのかイマイチよーわからんが

<meta name="keywords" content="Ruby,初心者,プログラミング" />
<meta name="description" content="プログラミング言語Rubyの初心者が集うスレです。" />

というようなののことを指してるのだと勝手に解釈

特定のページのkeywordsとdescriptionの2つにしか興味がないというのなら、
特定のページ専用の正規表現で最初にマッチする文字列を抜き出すのが素直だし時間もかからない

どんなページのどんな変態HTMLが来るのかわからないというのなら、HpricotとかのHTMLパーサを使うといい

241:デフォルトの名無しさん
08/03/08 16:39:04
>>240
レスありがとうございます。
おとなしく正規表現で取得しようと思います。

242:デフォルトの名無しさん
08/03/08 19:52:15
変数名を代入した変数を使って新しい変数を作るにはどうしたらいいですか?
PHPで言う$$var = 'value'
みたいなことをしたいのです

243:デフォルトの名無しさん
08/03/08 20:33:46
そんな曲芸みたいな処理は本当に必要なのか?

244:デフォルトの名無しさん
08/03/08 21:04:35
インスタンス変数ならinstance_variable_get/setで出来ることはできる。


245:デフォルトの名無しさん
08/03/08 22:05:57
Threadで引数に渡した値はthread内のローカル変数として使われて、他のスレッドの影響を受けないというような事が書いてありますが、つまりこういう事なんですか?

foo = 1
a=1
Thread.new( foo ){ | bar |
bar += 10
a += bar
hoge = a
}

この場合、barの値は他のスレッドの影響は受けないが、aは他のスレッドの影響を受けて値が変わってしまう。

bar は常に11が入っている状態になるが、aは他スレッドの影響を受けた場合、11とは限らない。

影響を受ける変数とそうでない変数との違いがいまいち分からん・・・。

246:デフォルトの名無しさん
08/03/08 22:45:41
え、単なる変数のスコープの問題なんじゃないん?

247:デフォルトの名無しさん
08/03/08 23:19:54
え、そうなん?
ちょっと考えてみる。。。

248:デフォルトの名無しさん
08/03/09 00:09:29
あ、ブロックの問題か。
他のスレッドの影響を受けるような物って、どうやって作るんだ。
あれあれ。

249:デフォルトの名無しさん
08/03/09 00:21:16
リファレンスの例がそのまま分かりやすいと思うけど

for i in 1..5
# スレッド内のiが書き換わる可能性がある
# Thread.start { p i }

# スレッド固有のローカル変数になる
Thread.start(i) {|t| p t }
end


250:デフォルトの名無しさん
08/03/09 01:04:04
それはブロックの問題にならないのか。。

#1
foo = 1
Thread.new{
foo +=10
}

ってのと
#2
for i in 1..5
Thread.new{ p i }
end

って両方ともスコープの問題なように思えてしまいます。
#2は他スレッドの影響で i の値が変わるのではなく、外側のスコープの
i が変わっているから変わってくるのでは?
#それともそういうつもりで書かれたんですかね。





251:デフォルトの名無しさん
08/03/09 01:25:56
ThreadのMutexの使いどころって言うのは、

1同じスコープを共有している
2同時に実行されている処理がある

1、2が当てはまる場合で、かつ2の両者が同じ変数をアクセスする際に
Mutexは使うべきなんだと思うんですが、スレッドの処理がまるまるメソッド化
されている場合はそもそも1が当てはまらないから、Mutexは必要ない
って認識でOKですか?

#ex.
i=0
th = []
def thread_run
puts i
end

1000.times{
th.push Tread.new{ thread_run }
}

while true
i += 1
puts i
end


252:250
08/03/09 01:30:13
いや、やっぱ

for i in 1..5
 Thread.new{ p i }
end

は他スレッドの影響を受けているのか。
そう公式リファに書いてあるもんなw

他スレッドの影響で i が書き変わって、
かつ、i はブロックの外側のスコープだから
影響を受けてしまうっちゅーことか。

253:デフォルトの名無しさん
08/03/09 08:35:45
スレッド生成した直後にスレッドの処理が終了するようなテストじゃ
よそのスレッドの影響受けてるかどうかもわからんだろ
for i in 1..5
 Thread.start(i) {|n| sleep(n) ; puts 'i = %d : n = %d'%[i,n] }
end

254:デフォルトの名無しさん
08/03/09 16:05:40
「特定のWebサイトにある特定の動的HTMLを取得して解析してデータを蓄積・別途表示するよスクリプト」
というありがちなものを頑張って作ってます

で、最近微妙にスレでも話題なRSpecとか使ってテストとかしようと思ったんですが、
「Webサイトに接続してHTMLを取得するかわりにローカルのHTMLファイルを読み込ませたい」です
定番の書き方とか方法とか考え方とかありますか

255:デフォルトの名無しさん
08/03/09 16:21:39
>>253
でたなsprintf厨

256:デフォルトの名無しさん
08/03/09 16:27:34
>>255
でも文字列への埋め込みよりは論理的にも見える
ていうか指示子覚えちゃったら結構どっちもどっちだよね

257:デフォルトの名無しさん
08/03/09 16:47:32
>>254
とりあえず
「アクセス用URIを作るクラス」
「URIを引数で受け取ってHTMLを取得しそのまま返すクラス」
「HTMLを引数で受け取って解析しデータ構造にして返すクラス」
「データを引数で受け取ってDBとかに保存するクラス」
とか細かく分けるんだ

258:デフォルトの名無しさん
08/03/09 16:56:12
>>253 がそうかは知らないけど
Python 使ってると Ruby でもそう書きたくなる
5.times じゃなくて for i in 1..5 してるのもそれっぽいと感じた
関数のカッコも省略してないし

259:デフォルトの名無しさん
08/03/09 18:57:30
Rubyのライブラリリファレンス本て結構いい値段するけど
ネットで見れるマニュアルに比べてのアドバンテージって何ですか?
検索も出来ないし、買う意味あるのかなーと思うんですが。

260:デフォルトの名無しさん
08/03/09 18:59:25
結局はwindowsのHTMLヘルプが一番いいね

261:デフォルトの名無しさん
08/03/09 19:01:28
>>259
金光編のなら、持ってますが、買う価値ないです。


262:デフォルトの名無しさん
08/03/09 19:10:21
>>259

・ まじめな意味でお布施
・ オンラインヘルプの利用ができない環境向け
・ 安くない本を買ったんだからと自分を追い込む用

263:デフォルトの名無しさん
08/03/09 19:17:12
return self
(returnなしでも桶)の効用がわかった気がする

264:デフォルトの名無しさん
08/03/09 19:24:33
半年前の自分のスクリプトはいい意味でも悪い意味でも読めないよね
Perlでの妙な凝りっぷりほどじゃないけどさ

265:デフォルトの名無しさん
08/03/09 19:41:28
ちょっと聞きたいんだけど、

irb(main):001:0> require "kconv"
=> true
irb(main):002:0> puts "シーソーゲーム".kconv(Kconv::UTF8, Kconv::SJIS).kconv(Kconv::SJIS, Kconv::UTF8)
シーメ[ゲーム
=> nil

ってやると元通りのものが帰ってきてくれないのはなんでなんだぜ?

266:デフォルトの名無しさん
08/03/09 20:02:55
rubyのバージョンとかは?

267:デフォルトの名無しさん
08/03/09 20:05:05
バージョンあんま関係ないと思うぞ
irb> p "シーソーゲーム".kconv(Kconv::UTF8,Kconv::SJIS)
"\343\202\267\343\203\274\343\203\241[\343\202\262\343\203\274\343\203\240"


268:デフォルトの名無しさん
08/03/09 20:09:06
それ単純に$KCODEが適切じゃないだけだと思う
puts "シーソーゲーム"でもシーメ[ゲームって出力されるだろ多分

269:デフォルトの名無しさん
08/03/09 20:23:12
$KCODEのデフォルトは日本語環境のWndowsであろうが、NONE


270:デフォルトの名無しさん
08/03/09 20:24:20
>>266
ruby 1.8.6 (2007-09-24 patchlevel 111) [i386-mswin32]

>>268
ぬぉほんとだ
勉強不足だったみたいだ 調べてくるありがとー

271:デフォルトの名無しさん
08/03/09 21:02:16
すまんもーいっこ聞きたいんだけど、ある変数ではSJISで、ある変数ではUTF8で持つとかってできないの?

test = "シーソー"
puts test.kconv(Kconv::UTF8, Kconv::SJIS)

で、ruby -Ks hoge.rb とかすると意図した通りUTF8で"シーソー"って出てくるけど、$KCODE = "SJIS"とかだとうまく動いてくれんのだが…
2種混在とか無理なのか?

272:デフォルトの名無しさん
08/03/09 21:10:17
>>271
できるよ
というかStringオブジェクト自体には文字コードの情報は付記されてない
内容を表示したり正規表現にマッチさせたりするときに利用メソッド側で改めて調べてる

273:デフォルトの名無しさん
08/03/09 21:24:28
>>272
そうなのかー
リファレンス見ると、KCODEが影響するのは
* インタプリタの字句解析器 etc
って書いてあるけど、これって例えば
test = "シーソー"
の "シーソー" を評価するときにKCODEを元に評価してtestに代入するってこと?

つか
$KCODE = "SJIS"
test = "シーソー"
puts test
ってやっても文字化けるのが納得いかん
irbとかでやると化けずにでるのも意味がわからん…

274:デフォルトの名無しさん
08/03/09 21:35:55
#!ruby -Ks
test = "シーソー"
puts test

275:デフォルトの名無しさん
08/03/09 21:38:31
>>274
それでちゃんとできるのは知ってる
$KCODEだとできたりできなかったりするのが不思議な昨今です

276:デフォルトの名無しさん
08/03/09 21:41:34
>>273
あ、悪い、$KCODEについては誤解がけっこう蔓延してる
$KCODE='s'はRubyスクリプトだから、これが解釈されるということは既に実行済みってことでそのファイルについては手遅れなんだ
(それ以降にrequireとかで読み込んだファイルは$KCODEにしたがって解釈してくれる)

スクリプトの先頭からShift_JISだと認識した上で読み込んで実行してくれないと困るので、普通は-Ksを使う
Windows版Rubyでも、 1行目に
#!ruby -Ks
とか適当に書いておくだけで、スクリプト解釈前(構文木生成前)に適当に解釈してくれる

スクリプトを読み込む
    ↓ -Ks の出番
スクリプトを解釈する
    ↓
プログラムを実行する
    ↓ $KCODE='s' の出番


277:デフォルトの名無しさん
08/03/09 21:48:52
スクリプト中に書き込まれた日本語文字列に駄目文字がなければ
$KCODE='NONE'(つまり #!ruby -Ks 無し)でも動くんだよ
駄目文字があった場合はうまく動作しない
Ruby作者さんも言っとる

URLリンク(blade.nagaokaut.ac.jp)
> まつもと ゆきひろです
> |あまりよい解決方法ではないかもしれませんが,二行目に
> |$KCODE='SJIS'
> |とするとruby -Ksと同じ挙動になると思います.
> |
> |#!/usr/bin/env ruby
> |$KCODE='SJIS'
> |
> |のような感じでどうでしょう.
>
> 残念ながら「$KCODE='SJIS'」の解釈は実行時に行われるので、プ
> ログラムの読み込みを行う時点での処理が行われません。たとえば
> ソースコードがSJISであった場合に文字列中の「表」などの処理が
> 適切に行われないことになります。


278:デフォルトの名無しさん
08/03/09 22:21:01
require したファイルの名前って一覧できますか。


279:デフォルトの名無しさん
08/03/09 22:23:14
>>278
irb> p $"
["irb.rb", "e2mmap.rb", "irb/init.rb", "irb/context.rb", "irb/workspace.rb", "irb/extend-command.rb",
"irb/ruby-lex.rb", "irb/slex.rb", "irb/ruby-token.rb", "irb/input-method.rb", "readline.so", "irb/locale.rb",
"kconv.rb", "nkf.so"]


280:デフォルトの名無しさん
08/03/09 22:25:29
>>278
$" ($LOADED_FEATURES)



281:デフォルトの名無しさん
08/03/09 22:27:09
>>279,280
さんくすです

もいっこ質問。
PHPとRubyとで、Webアプリのセッション情報を共有することはできますか。

282:デフォルトの名無しさん
08/03/09 22:28:59
>>281
テキストでファイルに保存あるいはテキストベースで遣り取り可能ならできんじゃね

283:デフォルトの名無しさん
08/03/09 22:36:49
memcachedとかでもイケそう。


284:デフォルトの名無しさん
08/03/09 22:51:30
セッション情報って別に形式決まってないよな

285:デフォルトの名無しさん
08/03/09 23:44:58
>>276
そうなのかー
$KCODE = "SJIS"を読んだ時点で設定が変更されんのかと思った
つーことはファイル毎に文字コードの設定が可能ちぅことか

>>277
ソースまで発掘してもらって申し訳ねぇ
でも2行目でやればいいってのはなんでなんだろう?
Rubyってインタプリタなんじゃないの?
読み込んだ片端から逐次実行なんじゃないの?
わかんねー

286:デフォルトの名無しさん
08/03/10 00:09:27
1.8は構文木、1.9は中間コードに一旦変換してるが、インタプリタには違いない
URLリンク(ja.wikipedia.org)

287:デフォルトの名無しさん
08/03/10 00:14:18
1. -Kオプションを解釈
2. パース
3. 実行

ソース中の「表」とかが問題になるのは2の時点、
$KCODEへの代入が実行される3の時点では手遅れ

288:デフォルトの名無しさん
08/03/10 00:32:56
>>286-287
全部一旦構文木にしてから実行すんのか?
Rubyって前方宣言じゃなかったっけ?

前方宣言だよなぁ→読み込み即実行だよなぁ→$KCODEに値代入した時点で即有効になる気がするよなぁ
っていう発想なんだが…

289:デフォルトの名無しさん
08/03/10 00:42:34
宣言してるというより実行時に作り上げてるだけ

290:デフォルトの名無しさん
08/03/10 02:01:50
なんか勝手な前提で色々考えてる感があるが…
$KCODE = "SJIS"
↑これだって単なる代入式なんだから実行されるまで作用しないだろ。

前方宣言どころかクラス定義やメソッド定義まで実行文だぞ。

291:デフォルトの名無しさん
08/03/10 06:51:16
配列自体をeachで変更したいのですが、どうしたらいいですか?
破壊的メソッドは!を付けるので
each!とかやってみたのですが駄目でした

292:デフォルトの名無しさん
08/03/10 07:00:14
>>291
要素数が同じでいいなら普通はmap!やcollect!を使う

irb> arr = [1,2,3]
irb> arr.map!{|e| e*2}
irb> p arr
[2, 4, 6]

293:デフォルトの名無しさん
08/03/10 07:04:59
>>292
おお!ありがとうございました

294:デフォルトの名無しさん
08/03/10 07:19:01
mapでの写像を覚えるとRubyコードのステキ度が100単位でアップするので超お勧め

「配列の要素をひとつずつ取り出して計算してひとつずつ格納する」から
「ある配列にブロックを作用させてもうひとつの配列を作る」という思考と記述が自然に行えるだけで超絶パラダイム
昨日までの小学生レベルのプログラムの勉強とはオサラバよオ・サ・ラ・バ

295:デフォルトの名無しさん
08/03/10 16:36:07
WinXPで音声編集をできるライブラリがあったら教えてください。
RAAを見た限りではなさそうですが。

1. 1秒以上の無音部分で音声ファイル分割
2. file1とfile2を、間に1秒無音部を入れて結合

というような事をやりたいです。



最新レス表示
レスジャンプ
類似スレ一覧
スレッドの検索
話題のニュース
おまかせリスト
オプション
しおりを挟む
スレッドに書込
スレッドの一覧
暇つぶし2ch