Ruby 初心者スレッド ..
[2ch|▼Menu]
573:デフォルトの名無しさん
08/10/14 02:10:57
サブネットマスクにマッチするような判定って簡単に出来ますか?
例えば、
"192.168.0.45".in_mask?("192.168.0.0/24") # => true
"192.168.0.45".in_mask?("192.168.0.0/29") # => false
となってほしいのです。

574:デフォルトの名無しさん
08/10/14 02:15:25
本質的にサブネットマスクはbitmaskだから
ANDしてやればいい

575:デフォルトの名無しさん
08/10/14 03:03:18
>>573
IPAddr#include?


576:デフォルトの名無しさん
08/10/14 07:48:35
rubyはじめたばかりのものです。

Windowsにて、ワンクリックインストーラでrubyをインストールし、
RMagick(とImageMagick)をインストールしました。
サンプルプログラムを走らせようとすると(ruby sample.rb)、以下のようなエラーメッセージが出ました。

./RMagick.rb:2: uninitialized constant Magick (NameError)
from D:/Programs/ruby/lib/ruby/site_ruby/1.8/rubygems/custom_require.rb:
27:in `gem_original_require'
from D:/Programs/ruby/lib/ruby/site_ruby/1.8/rubygems/custom_require.rb:
27:in `require'
from rmagick.rb:1

ファイルの内容は以下です。

require 'RMagick'
include Magick
img1 = ImageList.new("d:/a.bmp")
img2 = img1.blur_image(0,2)
img2.write("sample01.bmp")
exit

色々と試した結果、上記ファイルがあるディレクトリ(D:\rubyとする)をカレントディレクトリとして、
cmd.exeからruby sample.rbとすると上記のエラーが発生しますが、カレントディレクトリがd:\の
場合は正常に実行されました。どうもカレントディレクトリに*.rbなファイルがあると失敗するようです。
irbでも同様の結果でした。

これを回避する方法はないものでしょうか?

577:デフォルトの名無しさん
08/10/14 09:35:18
そろそろ解決してる頃だろうか

>>576
require 'hoge' は カレントディレクトリの hoge.rb ファイルを読み込む
rmagick.rb (大文字小文字問わず)という自作ファイルを改名しろ

「hoge ライブラリを試そうとして hoge.rb を作って実行し、次にまた別のスクリプトを作って変なエラーにはまる」というのは
そろそろ FAQ にしてもいいと思う

578:デフォルトの名無しさん
08/10/14 09:46:44
>>577
ああ、まさにそれでした。
5時間くらい悩んでの書き込みだったので、今はRMagickのマニュアルを読んでました。
有難うございました。

579:デフォルトの名無しさん
08/10/14 20:24:43
文字列中のすべての"\"を"\\"に、"'"を"\'"に置きかえたいときに
gsubってものすごくつかいづらいんですけど、
なんか他にいい方法はありませんか?


580:デフォルトの名無しさん
08/10/14 21:00:31
str.gsub(/['\\]/){|s|"\\#{s}"}
十分簡潔に思うが、どの辺が使いづらく感じた?

581:デフォルトの名無しさん
08/10/14 21:19:06
str.gsub(/['"]/) { %Q|¥¥#{$&}| }
あたりで手を打たないか?


582:デフォルトの名無しさん
08/10/14 21:19:40
遅すぎたリロード


583:デフォルトの名無しさん
08/10/14 21:42:38
ブロック使わずに表現できないの?

584:デフォルトの名無しさん
08/10/14 21:45:41
str.gsub(/([\\'])/, "\\\\\\1")

・・・うん、ブロックのほうがいい。

>>579-580
後方参照使わずにgsub繰り返すっていう力押しをしてた人が
ハマるパターンだろうね。

585:デフォルトの名無しさん
08/10/14 22:04:09
>>580
なるほど、ブロックを使えばいいんですね。

>十分簡潔に思うが、どの辺が使いづらく感じた?
perl なら、 s/([\\'])/\\\1/; と、比較的直感的なところを
>>584 のように"\\\\\\1"と書くとバックスラッシュが多くなりすぎて
後で読みにくいと思ったわけです。


586:デフォルトの名無しさん
08/10/14 22:06:36
おっと、 s/([\\'])/\\\1/g; でした。

587:デフォルトの名無しさん
08/10/14 23:56:30
str.gsub(/[\\']/, /\\\&/.source)


588:デフォルトの名無しさん
08/10/15 00:44:09
Windows限定でいいんですけど、OSが32ビット版か64ビット版か調べる方法はあるでしょうか。
ENV["OS"]だと32bit版XPでも64bit版XPでも"Windows_NT"と表示されて区別が付きません。



589:デフォルトの名無しさん
08/10/15 00:51:21
Ruby関係ねえええ

ENV['PROCESSOR_ARCHITECTURE'].include?('64') が true なら 64BitなCPUなのできっと 64Bit版Windows
URLリンク(support.microsoft.com)

590:デフォルトの名無しさん
08/10/15 01:06:42
じゃあruby関係で
ruby -e 'p RUBY_PLATFORM'

64bit環境を持ってないのでどんな出力がされるのかは知らんけど

591:デフォルトの名無しさん
08/10/15 01:10:11
RUBY_PLATFORMはコンパイル時に決まりそう

592:デフォルトの名無しさん
08/10/15 01:15:50
Fixnumを地道にカウントアップしていってBignumになる境界を見つける -> そこから推定
とかそういうアホを思いついた

593:デフォルトの名無しさん
08/10/15 01:21:56
64bitのOSで32bitのバイナリ使ってたら無理じゃないか

594:デフォルトの名無しさん
08/10/15 02:22:11
WIN32 API の GetSystemInfo() とか呼んだら良さそうな気がする。
呼び方はあれ、dl 使うなり何なり工夫してくれと。

595:デフォルトの名無しさん
08/10/15 03:01:15
Ruby の Web アプリケーションによくでてくる、

class CGI
def valid?( param, idx = 0 )
self.params[param] and self.params[param][idx] and self.params[param][idx].length > 0
end
end

というコードの著作権者、またはライセンスってわかりますか?
GPL だとしてもソースを配布する際には著作権表示が必要ですよね。

tDiary や hiki にも登場していますが、特別そういう表示がないので
勝手に使っても差し支えないんでしょうか?

596:デフォルトの名無しさん
08/10/15 03:12:41
その程度の誰が書いても同じになるコードには
著作権が発生するほどの創作性はないよ。

597:デフォルトの名無しさん
08/10/15 06:11:16
適当に書き換えればおk

if self.params[param]
if self.params[param][idx]
if not self.params[param][idx].size.zero?
return true
end
end
end
return false


598:デフォルトの名無しさん
08/10/15 06:42:47
>>588
64bit の Windows で試していないから動いたらラッキーぐらいで

require 'Win32API'

GetCurrentProcess = Win32API.new('kernel32', 'GetCurrentProcess', 'v', 'i')
hProcess = GetCurrentProcess.call()
isWow64Process = "\0" * 4
is64BitWindows = false
begin
 IsWow64Process = Win32API.new('Kernel32', 'IsWow64Process', ['p', 'p'], 'i')
 IsWow64Process.call(hProcess, isWow64Process)
 is64bitOS = true unless isWow64Process == "\0" * 4
rescue RuntimeError
end
p is64BitWindows

599:デフォルトの名無しさん
08/10/15 07:08:01
CamelCaseキモすぎる

600:デフォルトの名無しさん
08/10/15 08:10:27
PascalCaseだね

601:デフォルトの名無しさん
08/10/15 08:20:52
LCCだろ

さりとて、Windows の API にはハイフン区切りは似合わないのも事実

602:デフォルトの名無しさん
08/10/15 08:25:44
CamelCaseは力強さを感じる

603:デフォルトの名無しさん
08/10/15 12:36:20
MSは先頭大文字のCamelCase好きだよね
クラス名でもないのに何故?と違和感を感じる

604:デフォルトの名無しさん
08/10/15 14:33:09
クラス名は許せるが、rubyでは_区切りとisPredicateではなくpredicate?を使ってほしい

605:デフォルトの名無しさん
08/10/15 15:06:15
>>604
>isPredicateではなくpredicate?
変数に?使えたっけ

606:デフォルトの名無しさん
08/10/15 15:17:48
使えないよ。
けどpredicateってことは多分604はメソッド名のつもりで言ったんだと思う

607:デフォルトの名無しさん
08/10/15 17:14:47
何気に
attr_reader :hoge?
って書けないんだよな

608:デフォルトの名無しさん
08/10/15 20:37:53
@hoge? がだめだからなぁ。
Module#attr_readerが再定義されていればその限りじゃないぜ
意義はないけど。

609:デフォルトの名無しさん
08/10/15 20:39:11
?付きメソッドを定義したくなるのはよくあることなのに、attrで定義できないのがな・・・
自分でattr_readerを拡張するか、rubyplusのboolattr使うと便利
つーかActiveSupport辺りにも入ってそうな気がする

610:デフォルトの名無しさん
08/10/15 21:32:47
?付きメソッドを自分で定義すれば済むだけなので、漏れは必要ないかなあ。

611:デフォルトの名無しさん
08/10/15 21:48:34
>>610
メソッドごとに一つ一つ?付きを定義していくのって凄く面倒じゃね? 変更に弱くなるし

612:デフォルトの名無しさん
08/10/15 21:59:26
?末尾のシンボルを渡されたら、メソッド名はそのままに
末尾削った変数にアクセスするっていうのも便利かもしらんね

でも真偽値のアクセサが面倒になるほど多いっていうのも
設計見直せる可能性はない?

613:デフォルトの名無しさん
08/10/15 22:29:30
class Hoge
 def self.def_predicate(name)
  attr_accessor name
  private name
  private "#{name}="
  define_method("#{name}?"){ __send__(name) }
  public "#{name}?"
 end

 def_predicate :hoge
end

こんなんとか。リフレクションを用いるほど多く使うんじゃなければ
ちゃんと書いたほうがいいと思うけど

614:デフォルトの名無しさん
08/10/15 22:40:14
>>611
>>612の言うように?付きメソッドをそんなに定義することあるかな?

615:611
08/10/15 22:43:31
>>612 >>614
4〜5つ程度の?付きメソッドでも、似たような定義を続けて書くことになるからかなり面倒だと俺は思う
この辺は個人の意見もあるとは思うが

616:デフォルトの名無しさん
08/10/15 22:51:08
attr はあまり使わない
メソッドはきちんと定義する

617:デフォルトの名無しさん
08/10/15 23:34:27
そもそも @hoge? ができないことに疑問を感じるんだが

618:デフォルトの名無しさん
08/10/15 23:45:48
だから ? つきはメソッドだっつーの述語だっつーの

data= っていう変数が作れないのは不自然か?
change! っていう変数が作れないのは不自然か?

619:デフォルトの名無しさん
08/10/15 23:56:18
@is_foo みたいな変数名をどれだけ見かけることか
変数名が述語になれないのはおかしい

620:デフォルトの名無しさん
08/10/16 00:08:25
@hoge? = 123
まず見た目がきもい
そして三項演算子の文法と衝突しそう

621:デフォルトの名無しさん
08/10/16 00:08:33
変数名が述語になるほうがおかしい飢餓す

622:デフォルトの名無しさん
08/10/16 00:12:41
@foop か @foo_p でいい

623:デフォルトの名無しさん
08/10/16 00:14:27
「○○が二者択一のどちらかか、を格納する変数」というのはあまり Ruby っぽくない
二者択一の判断自体をメソッドで参照するのがフツーな気がする

624:デフォルトの名無しさん
08/10/16 00:32:23
>>620
そんなこと言ったらメソッド foo? がどんなオブジェクトも返すことのできる点もおかしくないかい?

625:デフォルトの名無しさん
08/10/16 00:36:58
見た目がきもい、ってのはほんとに見たまんま、?で終わる識別子が左辺値にくるのが
きもいってことだよ。
別に @hoge? = true ならいいってことじゃない

626:デフォルトの名無しさん
08/10/16 00:41:29
>>621
変数名とメソッド名の間で、言葉づかいの上でのセマンティックスが違っている「べき」なら、attr 系は廃止すべきってことになるな

>>625
@hoge? = true なら悪くないと思うけど

627:デフォルトの名無しさん
08/10/16 00:46:06
やだよ。
メソッド名の慣習のせいで、「hogeっすか?」って訊いてるようなイメージがあるじゃん。>@hoge?
で、「そうっすよ」とか「違いますよ」とか返事しようとしてるところに値突っ込むってのは変な感じだ。観念的な言い方でアレだが

628:デフォルトの名無しさん
08/10/16 00:50:34
何も @hoge? があってもそう書かなきゃいけないわけじゃないから、? を使わない自由を奪っているわけではないでしょ。
それよりも、attr 系によって変数名とメソッド名を関連付ける機能が提供されているにもかかわらず、? 付のメソッドだけ特例でそれができないほうが一貫性に欠けて嫌だ。

629:デフォルトの名無しさん
08/10/16 00:54:28
>変数名とメソッド名を関連付ける機能
単なるメソッド。とあるリフレクションのラップなだけ。

>? 付のメソッドだけ特例でそれができない
できないのはそこじゃなくて変数名に?を付けること。
でもってこっちは処理系本体の機能の話。

パーサとかに手を入れて?付き変数を許してまで@hoge?とか書きたいか?

630:デフォルトの名無しさん
08/10/16 00:58:26
そりゃ現状じゃ @hoge? が書けないようにパースしてるんだから、パーサを変えるしかないわな。
別に難しいことじゃない。
あと、attr_reader が処理系そのものが提供しているかどうかなんて関係ないじゃん。飽くまで意味論の話だし、built-inで入ってるんだから。

631:デフォルトの名無しさん
08/10/16 01:02:56
だって…再定義できるもの

632:デフォルトの名無しさん
08/10/16 01:06:57
>>627
メソッドvalueと変数@valueがあったとして、メソッドのほうは「valueは何か?」と問う意味なのに対して@valueはそのままの意味だよね?
同じようにhoge?がメッセージだと解釈されても、@hoge?までメッセージと解釈する必要はないのでは?

633:デフォルトの名無しさん
08/10/16 01:20:26
変数名だからその通りなんだけど、あくまでイメージというか馴れや先入観の問題だよ。>@hoge?がメッセージっぽい

また別の問題として、
変数名に?が付けられて、attr系もそんな名前を受け取るとすると
hoge.foo? = true とか
hoge.bar! = false とかが出て来る。後者なんて比較の否定と見間違う。

さらにいうと、?や!を許すとして、[]とか[]=とか@-は変数名に許す? 全部メソッド名としては有効なはずだよ。
attr_accessor :foo=
-> foo.foo= = 123
こんなことになる

634:デフォルトの名無しさん
08/10/16 01:44:47
hoge.foo? = true はできてもいいと思う。
hoge.foo! = ってのはまあちょっとヘンだけど、attr系で ! つけたかったことないから、あってもなくてもいいや。
[] や = が「メソッドの一部である」というのは別の側面で筋を通すための論法であって必ずしも名前の一部ではないので
(その証拠にメソッド「foo=」は、「foo.foo = 」のようにスペースを入れることができる)、
attr_accessor :foo= 等はなくてもよいかと。

635:デフォルトの名無しさん
08/10/16 01:55:24
>その証拠にメソッド「foo=」は、「foo.foo = 」のようにスペースを入れることができる
いやいや、メソッド名はあくまで「foo=」だよ。__send__(:foo=, 123)とか出来る。
パーサが頑張って「foo.foo = value」を「foo.foo=(value)」と同じような扱いにしてくれているだけで。

636:デフォルトの名無しさん
08/10/16 06:05:11
隔離スレでやれ

637:デフォルトの名無しさん
08/10/16 09:41:53
本スレが隔離スレってのも難儀な話だよなあ

638:デフォルトの名無しさん
08/10/21 07:15:54
RDEのツールバーとコンソール窓の設定などが上手く動作してくれません
ツールバーを移動して1段にまとめたりしても、RDEを最起動すると別の位置へ
勝手に移動した状態になってしまいます
コンソール窓は、フォントの設定が初期値に戻ってしまうのと、
ctrl+alt+cで開閉したりができません

コンソール窓のフォント設定だけは致命的なんで、そこだけでもなんとかできればと

639:638
08/10/21 07:27:47
一応環境も
ActiveScriptRuby 1.8.7(p72)
Windows XP SP3
です

640:デフォルトの名無しさん
08/10/21 14:20:14
ツールバーの問題は俺の環境(XP)では何年も前からあるよ。

641:デフォルトの名無しさん
08/10/21 15:51:59
てかRDE薦めてるサイトでもあるのか?
俺なら間違ってもRDEなんて使わせないんだが

642:デフォルトの名無しさん
08/10/21 15:56:44
統合環境使わせるなら EclipseかNetBeansあたりじゃね?

643:デフォルトの名無しさん
08/10/21 15:58:04
本筋以外での障壁が大きいからねえ…
「我慢して使う」時点で何か間違っとる
素直にエディタとプロンプトをAlt+Tabで切り替えて使うほうがマシ

644:638
08/10/21 17:13:53
コンソール窓のフォント設定は自分のミスでした
コンソール窓で右クリして「設定」からフォントを設定していたのですが、
直ぐ上に「フォント」というのがありました… 見逃してました

>>640
どもです
ツールバーはしょうがないみたいですね

>>641-643
どもです
winの人がrubyを始めようと思うと、RDEがまず最初に目に入るような気がします
NetBeansはDLしてあったのですが、JAVAが云々…とまたやることが増えそうなので
後回しになってました
とりあえず簡単なプログラムを書いて試したかったので、RDEをという感じで
日常はEmEditorのフリー版(かなり古い)を使っていたので、それでやればよかったのですが
コマンド操作には不慣れなwin人なんで、お手軽(そう)なRDEから初めてみようと思い

初心者〜中級者?への道筋がすっぽり抜けてる感じがしていて先行き不安ですが
書いて直ぐ実行できるのはやっぱり楽しいし勉強になります

645:デフォルトの名無しさん
08/10/21 18:04:59
RDEはirbと似たような感じでSandBoxとしてしか使わないなぁ。
ファイルに保存はしなきゃならんけど、EmEditorも言語モード別のキー設定と、
外部プログラムのを実行して標準出力を下窓に出す機能が(少なくともVer6からには)
備わってるから、キー1発で実行はできるよ。

646:デフォルトの名無しさん
08/10/21 18:48:59
RDEはいろいろなところで紹介されてるから、知名度はかなり高いし
動作はけっこう軽くて多機能、日本語対応と利点は多い
が、不安定さ(特に文字コード関連)とレジストリ使用がそれらの魅力を帳消しにしている

647:デフォルトの名無しさん
08/10/21 19:42:48
RDEを普段使ってない人がファーストインプレッションあるいは又聞きで薦めてんじゃないかと思ってる
普段から使っていれば、少なくとも初心者には勧めようとは思えないはずだ

単一言語用だからといってIDE作成が簡単になるわけではない
1種類の言語にしか対応しなくても、10種類の言語に対応してても、IDEとしての作り方は同じだと思う
Rubyに特化すればIDEが俺でも作れそうとか最初に思った人は罪深いなと思ってみる

648:デフォルトの名無しさん
08/10/21 19:58:42
FreeRIDEが日本語や他の文字コードに対応してくれれば無敵なんだが

649:デフォルトの名無しさん
08/10/21 22:52:51
rubyの表記法の質問なのですが、
Test::Sample
のように書かれていたら、TestとSampleはともにクラスでTestがSampleの親クラス
という認識で合ってますか?
::という記号は定数やクラス変数なども表すとネットで見たのですが
区別は付くのでしょうか?

650:デフォルトの名無しさん
08/10/21 23:13:36
:: は 「の」 だ
Test::Sample は Test 「の」 Sample だ
それ以上の意味はないよ
クラスかどうかは普通に識別子で判断する
先頭が大文字なら定数かクラス
先頭が小文字かアンダースコアならメソッド
ただ、あからさまに面倒なのでメソッドを :: で繋ぐことはRubyでは意図的にしない
(他の言語での書き方をしないと死ぬ人が稀に使う)

651:649
08/10/22 00:09:42
>>650
ありがとうございます。
そんな曖昧なものだったんですね。メソッドは#でしたっけ?
この業界っていやに自己主張強い人が多いから統一できないのかな

652:デフォルトの名無しさん
08/10/22 07:50:20
RDEってRubyのサンプルプログラムとして付いているもんだと思ってた・・・

653:デフォルトの名無しさん
08/10/22 09:30:08
>>651
スクリプト上での表記とマニュアルでの表記は違う

…違ってちゃいけないと思うんだが、まあ、
「○○クラスのインスタンスメソッド××を…」と書く代わりに「○○#××を…」と
「○○クラスのクラスメソッド××を…」と書く代わりに「○○.××を…」と
「○○クラスの定数××を…」と書く代わりに「○○::××を…」と書けたほうが
一度理解してしまえば便利ではある

654:デフォルトの名無しさん
08/10/22 18:04:18
>>653
> スクリプト上での表記とマニュアルでの表記は違う
>
> …違ってちゃいけないと思うんだが、まあ、

とはいえ、あるクラスのインスタンスメソッドというのは、直接コード上には
現れないから、そもそも同じ表記にはしようがない。
いちいち X.new.m とか書くのもめんどくさいだろ。


655:デフォルトの名無しさん
08/10/22 20:22:05
>>650
Test::Sample だったら普通はmoduleかclassがネストされてるやつじゃね?

656:デフォルトの名無しさん
08/10/23 09:59:06
>649
::で示されるのは主に
・モジュール内クラス
・クラス内クラス
・モジュール内モジュール
・クラス内モジュール
・モジュールの持つ定数
・クラスの持つ定数
などであって、クラス間の親子関係ではない。
どちらかと言えば所有、もしくは所属の関係。

657:デフォルトの名無しさん
08/10/23 17:43:37
Windowsなら、既に更新停止状態だがJmEditorでぜんぜんいける。
コマンドライン登録しとけば、キー一発で実行できるし、プロンプト
勝手に閉じてほしくないなら、ruby.exe実行してからpauseするバッチ
ファイル登録すればいい。

658:デフォルトの名無しさん
08/10/23 18:56:51
まさかJmEditor使いが俺の他にもいたとは
動作軽いしUSBで運べるし、便利だよね

659:デフォルトの名無しさん
08/10/23 22:50:55
irb とかでいっつも忘れるんだけど、NKF.guess の返り値の数字と文字エンコード名の関係ってどっかに書いてないかな?

660:デフォルトの名無しさん
08/10/23 22:57:18
NKF.constants.map{|s|[NKF.const_get(s),s]}
こんな感じで出せばいいんじゃないか?

661:デフォルトの名無しさん
08/10/23 23:42:46
refeで引いてみたら出てるかと思ったが

$ refe NKF.guess
require 'nkf'
NKF.guess
--- guess(str)

文字列 str の漢字コードを判別して返します。
返される値は、NKF モジュールのモジュール定数です(下記参照)。
ruby 1.8.2 より前は現在の NKF.guess1 と同じものです。
ruby 1.8.2 以降では NKF.guess2 と同じものです。


下記参照て言われても、下記がない・・・

662:デフォルトの名無しさん
08/10/24 08:30:26
.chmもちあるけば解決するお

663:デフォルトの名無しさん
08/10/24 09:07:06
>>659
あれは inspect で文字列が出るべきだと思う

664:デフォルトの名無しさん
08/10/24 09:07:51
>>662
書いてねえって

665:デフォルトの名無しさん
08/10/24 10:01:53
>>664
キーワード:NKF.guess(str) (nkf)
でとんだページの下に定数が書いてあるけど・・・

666:デフォルトの名無しさん
08/10/24 11:02:43
> NKF.guess の返り値の数字と文字エンコード名の関係

667:デフォルトの名無しさん
08/10/24 23:52:29
ああ、そりゃソース嫁としかw

668:デフォルトの名無しさん
08/10/25 13:34:31
>>656
じゃあクラスの継承はどうやって表すの?

669:デフォルトの名無しさん
08/10/25 13:55:39
「表しようがない」が正解かと
「XXXを継承したYYY」のように文章で書くしかないな

670:デフォルトの名無しさん
08/10/25 23:39:57
Win32OLEを使ってエクセルの自動処理をしようと思っているんですがうまくいきません。

require 'rubygems'
require "win32/clipboard"
require 'win32ole'

excel = WIN32OLE.new('Excel.Application')
excel.visible = false
excel.displayAlerts = false

excel.workbooks.open 'filename' => 'foo'
workbook = excel.workbooks(1)
sheet = workbook.sheets(1)
sheet.select
excel.Columns("B:B").select
excel.selection.copy
excel.quit
↓に続く

671:デフォルトの名無しさん
08/10/25 23:40:47

class Excel
end
excel = WIN32OLE.new('Excel.Application')
WIN32OLE.const_load(excel, Excel)
excel.visible = true
excel.displayAlerts = true

book = excel.workbooks.add('bar')
sheet = book.worksheets(1)
sheet.Columns("B:B").Insert Shiftt = Excel::XlToRight

excel.Range("B1").ColumnWidth=11  #セル幅設定                       ←幅や領域が違うっていうエラーが出るのでなんとなく

excel.Columns("B:B").select
excel.selection.parent.paste

book.Save
excel.quit

エラーメッセージは以下
 `method_missing': paste (WIN32OLERuntimeError)
    OLE error code:800A03EC in Microsoft Office Excel
      Worksheet クラスの Paste プロパティを取得できません。
    HRESULT error code:0x80020009
      例外が発生しました

pastespecialなんてのも試してみてもダメ、エラーコードでググってもダメ、"ruby excel paste"などもググって見ましたがダメでした。
よろしくお願いします。

672:デフォルトの名無しさん
08/10/26 11:07:36
>>670-671
Excel.Application ペースト でググるんだ
Win32OLEの情報を探すときはRubyに限定しないほうが良い
俺excel持ってないから動作検証できないけどごめんね

673:デフォルトの名無しさん
08/10/26 12:43:20
関係ないけど gemで入れられる excel用のライブラリ見つけたぜ
spreadsheet-0.6.1.5 Documentation
URLリンク(spreadsheet.rubyforge.org)


674:670-671
08/10/26 17:37:00
>>672-673
ありがとうございます。解決しました。

原因は貼り付ける際に列で指定していたからダメだったようで、
貼り付ける先頭セルの値をRangeで受け渡したらうまく行きました。
また上のプログラムだとちゃんと保存できないのも注意です。
開き方の問題なのか読み取り専用になっているようです。
名前を付けて保存するようにしたらちゃんと保存されました。

675:デフォルトの名無しさん
08/10/26 19:29:35
掲示板スクリプトを作ってるんだけど、動かない。
どこがおかしいのかな。

使っているサーバー @pages (www4サーバー)

一応誘導を受けて来たので誘導元
□規制解除要望□ dion.ne.jp専用 Part727
スレリンク(accuse板)

スクリプトはここからダウンロードして
URLリンク(www4.atpages.jp)

676:デフォルトの名無しさん
08/10/26 19:33:52
excelのvlookupのようなものをrubyで書きたいのですが
遅いので速くしたいです。(元々excelのものが遅いのが発端です。)
アドバイスをいただけないでしょうか。
よろしくお願いします。

###################
想定する入力データ

1,0.25,2.25
2,0.75,1.76
3,1.24,1.24
4,1.76,0.75
5,2.25,0.25



677:676
08/10/26 19:34:59
#676の続きです
def Vlookup(vs,v)
vx=vs.to_f
if (vx<v[0][0]) then
return -99.9
break
elsif (vx>v[v.size-1][0]) then
return 99.9
break
end
for i in 0..(v.size-1)
vpre=v[i][0]
vpst=v[i+1][0]
if (vx>vpre)&&(vx<=vpst) then
if (vpre-vx).abs<=(vpst-vx).abs then
num=i
elsif (vpre-vx).abs>(vpst-vx).abs then
num=i+1
end
break
end
end
return v[num][1]
end


678:676
08/10/26 19:35:43
#677の続きです。
DAT=[[0.5,5.0,50.0],[1.0,10.0,100.0],[1.5,15.0,150.0],[2.0,20.0,200.0]]

lines=Array.new

open(ARGV[0],"r") do |f|
while line = f.gets
line.chomp!
lines=line.split(/,/)
lines[1]=Vlookup(lines[1],DAT)
lines[2]=Vlookup(lines[2],DAT)
print lines.join(","),"\n"
end
end


679:デフォルトの名無しさん
08/10/26 19:44:37
>>675
いきなり自作CGIをレンタルサーバーで動かすとか正気の沙汰ではないぞ
httpdのエラーログをみよう。
いやその前に、まずは、WindowsならばXAMPPでも入れてローカル環境で試そう、な


680:デフォルトの名無しさん
08/10/26 19:54:27
>>679
一応ローカルで実験はした。
方法
1.irbを起動する
2.環境変数を設定
3.systemコマンドで実行
結果
とりあえず動いた

だからアップロードしたわけだが。

681:デフォルトの名無しさん
08/10/26 19:58:41
結論:

 ・ 馬鹿にCGIを渡すな



682:デフォルトの名無しさん
08/10/26 20:02:38
>>681
一応Apacheをインストール中
ところで、WindowsのApacheでCGIを動かすとき#!の行はどうすればいい?

683:デフォルトの名無しさん
08/10/26 20:10:51
家の環境では、ruby.exeをapacheと同じドライブの例えばc:\usr\local\bin\ に放り込んでおけば動いた

684:デフォルトの名無しさん
08/10/26 20:12:44
パスは通しておいてね

685:デフォルトの名無しさん
08/10/26 20:12:47
>>682
パス通して#!rubyでいいんじゃね

686:デフォルトの名無しさん
08/10/26 20:13:15
> パスは通しておいてね
Ruby本体をインスコしたディレクトリにパスは通しておいてね

687:675
08/10/26 20:20:11
実験は成功した。普通に動いた。
今度は書き込みを実行したとき何も出力されないバグが出てきたが

688:デフォルトの名無しさん
08/10/26 20:34:55
cgi-exception入れとけ
URLリンク(cgi-exception.rubyforge.org)

689:デフォルトの名無しさん
08/10/26 21:02:28
>>688
ローカルでは動く。リモートでは動かない
cgi-exceptionをrequireしても(もちろんそのファイルごとアップロード済み)
まったくダメ。

690:デフォルトの名無しさん
08/10/26 21:07:27
この分だと向こうで拡張ライブラリの一部が欠損しているというオチの可能性が
高そう。標準添付のライブラリ(cgi,nkf)しか使ってないのに…

691:デフォルトの名無しさん
08/10/26 21:24:01
CGI.unescape(cgi.params['うんこ']) を CGI.unescape(cgi.params['うんこ'][0]) にするとかさ、
NKF,nkf(略) を NKF.nkf(略) にするとかさ、
変数名やGET/POSTパラメタの名前に誤りがないかよく見るとかさ。

692:デフォルトの名無しさん
08/10/26 21:26:19
環境を疑うよりは、まず自分のスクリプトを徹底的に疑うべき
CGI-Exceptionでエラーが出ないなら次はprintfデバッグだ
スクリプト中の適当な位置で、テキストファイルにログを書き出していけば
たいていエラー箇所を特定できる
(スクリプトが全く実行されない場合は、syntax errorかrubyパス絡みの可能性が高い)

693:692
08/10/26 21:37:21
あ、重要なこと書き忘れてた

初心者は(初心者じゃなくても一緒だけど)まず最小限のCGIスクリプトから書き始めろ
小さなスクリプトが動いてから、徐々に機能追加していかないと
ただでさえ特定しづらいCGIのエラーが、余計に特定しづらくなる

少なくとも、そこそこの長さがあって環境変数が関わるような掲示板スクリプトを
一気に書き上げるべきではない

694:デフォルトの名無しさん
08/10/26 21:55:34
>>691
それにはすでに気づいて直した。直したが治らない。
>>692
syntax errorがらみはありえない(-cオプションで検査済み)
パスもチェック済み(/usr/local/bin/ruby)
>>693
一応ローカルで動作確認済みなので

695:デフォルトの名無しさん
08/10/26 21:59:42
これはRubyの問題ではない(まだ)

>>694
だからその方法が間違ってると指摘されてるだろう
CGIは「ブラウザでInternalServerErrorが出なくなるまで書き直す」という手法で開発してはいけない
エラーメッセージを確認しない開発手法は糞だ

696:デフォルトの名無しさん
08/10/26 22:02:14
> 一応ローカルで動作確認済みなので
最小限のCGIスクリプトをサーバー上で動かさないとダメ
「環境変数自分で入れて、systemで実行して動いたから」というのではあまり意味がない

697:デフォルトの名無しさん
08/10/26 22:03:11
結論:

 ・ 馬鹿にCGIを渡すな



698:デフォルトの名無しさん
08/10/26 22:04:18
>>695
とりあえずちょいと方法が思い浮かんだので実験してみる

1.まずは単なるテストスクリプトが動くか確かめる
それすら動かないようならとりあえずこの環境での動作はあきらめたほうがよい
2.次にちょっとした工夫のなされたテストスクリプトを使って実験を行う
3.最後にその結果を見て検証する

699:デフォルトの名無しさん
08/10/26 22:04:55
RubyでWin32弄くる場合に必要な知識はRubyそのものではないのと同様に
RubyでCGIやる場合に必要な知識はRubyそのものではないのだな

ライブラリで吸収隠蔽すべきかどうかというのは悩ましいとこだと思う

700:デフォルトの名無しさん
08/10/26 22:05:14
>>696
Apacheでも動作確認済み
1時間以上前に実験した。

701:デフォルトの名無しさん
08/10/26 22:06:11
bbs.cgi:57: cgi.params['content']をCGI.unescapeに渡している
Arrayが渡ったりしてNoMethodError -> あぼーん
bbs:cgi:58: NKF,nkf('-s',content) カンマとドットのtypo

とりあえず2つみっけ
動作確認済みとは笑わせるな
それともHPのzipからまた弄ってるのか?

702:デフォルトの名無しさん
08/10/26 22:09:26
>>700
どう動作確認したのかkwsk
俺の環境でApache立ち上げて試してみたが、普通にアクセスしただけでエラーが出る
具体的には>>701

703:デフォルトの名無しさん
08/10/26 22:09:46
#!/usr/local/bin/ruby -Ks

print "Content-type: text/html\n\n"
print "<html><head><title>テスト</title></head><body><p>テスト</p></body></html>"

このスクリプトすら動作してないのでもはやお手上げ

704:デフォルトの名無しさん
08/10/26 22:10:02
>>699
だねえ

>>700
小出しにするな
自分で話をまとめられないなら諦めれ

705:デフォルトの名無しさん
08/10/26 22:11:17
> 小出しにするな
> 自分で話をまとめられないなら諦めれ

に一票
そして離脱

706:デフォルトの名無しさん
08/10/26 22:17:59
>最小限のCGIスクリプトをサーバー上で動かさないとダメ

に対して

>Apacheでも動作確認済み
>1時間以上前に実験した。
って…明らかに話噛み合ってないな

707:デフォルトの名無しさん
08/10/26 22:19:34
>>703
自分でApache立ち上げて試すときは、そのパスじゃまず起動しないぞ
#!ruby -Ks
にして試してみ。それでも駄目ならお手上げ

708:675
08/10/26 22:21:49
>>706
まったくかみ合わない上に、どうやらこちらの問題ではなさそうだと
判明したのでたぶんこれ以上話し合っても結論が出る可能性は0(正確には)

ただ、根本的バグが見つかったのは皆さんのおかげです。
皆さん、ご協力どうもありがとうございました。

709:デフォルトの名無しさん
08/10/26 22:24:45
>>707
もちろんローカルでやるときはそのためのパスにするわけですけどね。

710:デフォルトの名無しさん
08/10/26 22:31:12
>>707
Rubyの絶対パスを指定して動いてるので、いえるのは
もはやここでは対処しようのない問題だということです。
とりあえずテストスクリプトすら動かないということは
他のところに持っていったのでこれ以上の深入りは
避けたいと思います。

711:デフォルトの名無しさん
08/10/26 22:32:04
>>703
ステータスコード書いてないから動かなくて当然
あと\n\nだとサーバが非winのとき困るんじゃないか?

712:デフォルトの名無しさん
08/10/26 22:33:31
てゆーかbbs.cgi自体も割りと…たぶん2、3個の虫食いじゃないよな、
斜め読みした感じでも

713:デフォルトの名無しさん
08/10/26 23:01:23
パーミッションの設定してませんでした><

714:707
08/10/26 23:10:02
>>711
あ、そうか
NPH環境だとステータスコード無しでは動かないのか…

715:デフォルトの名無しさん
08/10/26 23:38:16
超遅レスだけど
>>656 >>668 >>669
ここら辺の話って本当なんですか?
Rubyのライブラリのレファレンスでクラスの説明とか見るとよく::が使われてるけど
あれは本当は間違いなんですか?

716:デフォルトの名無しさん
08/10/26 23:48:43
>>656以外の使い方してるやつなんてあんのか
具体的になんてライブラリのリファレンスのどの部分よ

717:デフォルトの名無しさん
08/10/27 00:17:15
>>676
「vlookupのようなもの」ってのが、一体どんなのか分からんのだが
vpreとvpstではさんで比較してるってことは、ソート済みだと仮定してもいいの?
良いなら二分探索が使える

コードについて
・Range#eachがあるんだからeachを使う。Rubyでforは(めったに)使わない
・不要なbreakが見られる
・異常入力に対して99.9とかを返すのは、これでいいの?

718:デフォルトの名無しさん
08/10/27 01:26:18
>715
マニュアル内でのその記述はクラスの親子関係じゃなくて、大抵モジュールの定数のハズ。

719:デフォルトの名無しさん
08/10/27 01:33:20
例えば、Objectクラス、IOクラス、Fileクラス、File::Statクラスの関係は

IO と File::Stat の直接の親は Object クラス
File は IO の子クラス
File::Stat は File の子クラスではない
File::Stat は File 内のクラス

Rubyのコードで書くとこんな関係。

class Object
end
class IO < Object
end
class File < IO
  class Stat
  end
end

720:デフォルトの名無しさん
08/10/27 01:34:23
言うなれば :: でクラス同士を繋いでいたら、それは親子じゃなくて入れ子の関係ってところか。

721:デフォルトの名無しさん
08/10/27 01:47:29
Railsの質問はここでいいんでしょうっか?
Web画面を共有出来るアプリが作りたいので
実験で5分で動くshootingstar使ったchatのテストアプリみたいなのを
動かしたんですけど自分でブラウザを更新しないと表示画面が更新されません。
バージョンは、shooting_star (3.2.7)とrailsは2.1.2でOSはUbuntuなんですけど。。

722:デフォルトの名無しさん
08/10/27 02:10:00
WebProg板にRailsスレあるよ

【Ruby】Ruby on Rails Part6
スレリンク(php板)

723:デフォルトの名無しさん
08/10/27 05:38:49
>>676
>>677-678の気になる点。

1.vの1列目の値が小さい順で並んでいないと動かない
 以後は1列目は昇順ソート済みであるものとする

2.vs == v[0][0], vs < v[1][0] なら (vs>vpre) && (vs<=vpst) は常に偽
 forの最終ループでvpstがvの範囲外となりエラーを起こす
 vpst = v[v.size][0] => vpst = nil[0]

3.VLOOKUPと検索の仕様が違う
 VLOOKUPは完全一致検索または検索値を超えない最大値の検索
 こちらは四捨五入もどきというか、小さい側優先の再近接値検索?
 (ちなみに四捨五入は中間値切り上げ丸め、つまり大きい側優先)

4.VLOOKUPと違って返値の列が2列目固定
 それならMATCH関数にした方がまだ使いやすくない?

724:デフォルトの名無しさん
08/10/27 05:45:45
>>677を問題点もそのままで、ちょっとRubyぽく書き直してみた

def Vlookup(vs,v)
 vx = vs.to_f
 return -99.9 if vx < v[0][0]
 return 99.9 if vx > v[-1][0]

 v.each_cons(2) do |vpre, vpst|
  if vx>vpre[0] && vx<=vpst[0] # *1
   return vx-vpre[0] <= vpst[0]-vx ? vpre[1] : vpst[1] # *2
  end
 end
 nil[0] # *3
end

*1 検索対象が昇順なら"vx>vpre[0] && " 部分は不要
  というか、ここを削れば問題点2は解消する
*2 3項演算子といってexcelのif関数のようなもの (cond ? retA : retB)
*3 問題点2のエラーを発生させるためのもの。
  *1の対策を実施すればこの行には到達しないので削除してよし

高速化とか一切していないので悪しからず。
>>717の言うとおり、二分検索するのがいいんでない。
適当にコード見て書いただけなんで、バグとか指摘の間違いとかあるやも。

725:デフォルトの名無しさん
08/10/27 05:51:25
>>711
ほぼ参考書のままです。
とりあえずステータスコードをつけて動くか確かめてみます

726:デフォルトの名無しさん
08/10/27 05:59:36
結局Content-typeの改行コードを\r\nにしたら動きました

727:デフォルトの名無しさん
08/10/27 06:22:47
>>726
それは誤りだ

728:デフォルトの名無しさん
08/10/27 07:26:44
>>727
一応めでたく完成して新しい追加機能2つ(日付表示・連投規制)を
付け加えました。たぶんこれで実運用上、書き込みがぶつからなければ
なんとかなると思います。タグ検索機能はなんか変ですが
おいおい何とかします。

729:デフォルトの名無しさん
08/10/27 08:20:38
>>727
誤りではないだろう、HTTPの標準改行コードは\r\nだ
出力先がバイナリモードでさえあれば問題はない

730:デフォルトの名無しさん
08/10/27 21:40:37
>>716 >>718 >>719
Java出身のruby初心者だったものでクラスライブラリはクラスの継承で繋がってると思い込んでました。
なるほど、rubyはモジュールや入れ子のクラスを多用するんですね。
勉強になりました。ありがとうございました。

731:デフォルトの名無しさん
08/10/27 22:15:18
Javaだってよく使うだろう。

732:デフォルトの名無しさん
08/10/27 22:25:44
RubyやPerlって一体なにに使う言語なんですか?

Htmlに組み込む言語という解釈でいいんですか?

733:デフォルトの名無しさん
08/10/27 22:41:28
>>732
だいたい何にでも使う

734:デフォルトの名無しさん
08/10/27 23:02:23
テキスト処理をするのに使う

テキスト処理と聞いて何も思いつかない場合はまだスクリプト言語に用がないということなので
PerlやRubyのことはすっぱり忘れて別なことを楽しみましょう

735:デフォルトの名無しさん
08/10/28 00:49:43
rubyはrailsのために使います。
フリーだと現時点で一番効率よく稼げるのrailsです。
3人月の案件で700は固いから月給200万ですよ。

736:デフォルトの名無しさん
08/10/28 17:05:00
日本語でおk

737:デフォルトの名無しさん
08/10/28 19:13:55
>>732
>Htmlに組み込む言語

それはPHP

738:デフォルトの名無しさん
08/10/28 20:26:14
>>737
HTMLがPHPになるんですか?
PHPがHTMLになるんですか?
組み込むってそういうことですよね?

739:デフォルトの名無しさん
08/10/28 20:54:46
画面分割はどうやればいいんですか?
自動的に隠したり、分割を×ボタンで消したりする機能のパックになったコントロールとかあるんですか?

740:デフォルトの名無しさん
08/10/28 20:57:37
>>739
Webクライアントの仕組みについて理解してから来なさい。


741:デフォルトの名無しさん
08/10/28 20:58:32
>>739
えーと…
Rubyの仕事ではないので、GUIに何を使ってるか調べて、それに関するスレなりサイトなりに行くといい

742:デフォルトの名無しさん
08/10/28 21:18:58
@蠣←これを右クリでコピーする
Aスタート→すべてのプログラム→アクセサリ→メモ帳を起動
B編集→貼り付け
C編集→すべて選択
D変換キーを押す

743:676
08/10/28 23:44:49
>>717
説明不足でした。私がやりたいのは、以下のものです。
・1列目にソート済みの数値が入っている
・2列目には1列目の各行に対応する数値が入っている
・ある数値(入力値)が来た時に1列目の中から最も近い値を探し、それに対応する2列目の値を返す
・もし入力値が1列目の数値の上下限から外れていたら、それぞれ99.9か-99.9を返す
です。

>・Range#eachがあるんだからeachを使う。Rubyでforは(めったに)使わない
始めたばかりなもので。。。今後はeachを使います。(ちなみに速度に差はありますか?)

>・不要なbreakが見られる
入力値が上下限から外れていたら、関数の中のif文より後のfor文にいれたくなかったので使いました。これを見てからelseに書き換えました。
(一般的にbreakは多用しない方がよいのですか?)

>・異常入力に対して99.9とかを返すのは、これでいいの?
異常を示す文字列にしようかとしましたが、今、私がやりたいことにおいて99.9で十分なのでこうしました。


744:676
08/10/28 23:45:30
>>723
>1.
書き忘れていましたが、ご指摘のとおりソート済みを仮定しています。

>2.
ちょうどそのエラーに出くわしていたところでした。。。

>3.
事前に一応調べてはみたのですが、ちゃんと理解できていなかったです。
また数学がよくわかっていないため、2の事態が発生しました。

>4.
MATCH関数を知らなかったので調べてみましたが、どのように適用すればよいかわかりませんでした。もう少し詳しく教えていただけないでしょうか。

>>724
知らない事がありすぎるのですが、みやすくなったので使ってみたいと思います。
速くなるのも教えていただけると助かります。。。

745:デフォルトの名無しさん
08/10/29 05:33:04
forは内部的にeachを呼び出すそうだから、速度差など無いに等しい。
どうしても気になるなら一億回くらい空ループ回して計ってみるといい。

まぁ、仮に10倍の速度差があったとしても、今は気にする必要ない。
プログラムの高速化はまず何よりもアルゴリズムが最優先。
小手先の最適化に手をつけるのはその後だね。


breakは単に使い方が悪い。
>>677の最初の2つは先にreturnするので、絶対に到達しない。
最後のはbreak後returnしかしていないので、returnで置き換え可能。
breakせずに抜けるパターンの場合、必ず範囲外アクセスで落ちる。
つまりすべての箇所で何の役にも立っていないというわけ。


異常入力にマジックナンバーを返すのもありだけど、発生頻度が低く
検査箇所が多いようなら例外(Exception)を発生させたほうがいいよ。
コードの見通しがまるで違ってくるから。


VLOOKUPは検査値に対応する行と指定した列が交差するセルの値を
返すのに対し、MATCHは検査値に対応する値の位置を返す。
VLOOKUPでは検索範囲が左端の列で、かつ対応する値の列の高さと
縦位置が完全に一致しなければいけない。

MATCHとINDEXまたはOFFSETとの組み合わせなら、検査列に対応
する値の列が左にあってもよいし、縦にずれていてもよいし、列でなく
行(対応する値が横に並ぶ)でもよい。
その気になれば対応する値をnマスおきに飛び飛びにだってできる。
それに比べると列指定不可のVLOOKUPなんてあまりに不便すぎる。

746:デフォルトの名無しさん
08/10/29 05:37:23
MATCH関数もどき。 返値は0を起点とする点が異なる。
直近値検索方法は>>677と同じ。

def match_liner(val, array) # >>677と同等
 array[0...-1].each_index do |i|
  if val <= array[i+1]
   return val-array[i] <= array[i+1]-val ? i : i+1
  end
 end
 array.size - 1
end

def match_recursive(val, array)
 case array.size
 when 0
  nil
 when 1
  0
 when 2
  val-array[0] <= array[1]-val ? 0 : 1
 else # ↑↓ 不等号に注意のこと
  i = array.size / 2
  val < array[i] ?
   match_recursive(val,array[0..i]) : match_recursive(val,array[i..-1]) + i
 end
end

747:デフォルトの名無しさん
08/10/29 05:40:31
ベンチマーク

srand 1.0 * 2008/10/29 * 3*14 * 0xdeadbeaf # 乱数の種を設定
lookup = Array.new(100000){ rand }.sort!
data = Array.new(2000) { rand }

Benchmark.bm do |x|
 x.report { data.each do |v| match_liner v, lookup end }
 x.report { data.each do |v| match_recursive v, lookup end }
 x.report { data.each do |v| match_loop v, lookup end }
end
   user   system   total    real
221.528000  0.040000 221.568000 (237.392000) # 線形検索
 0.501000  0.000000  0.501000 ( 0.550000) # 二分検索(再帰)
 0.140000  0.000000  0.140000 ( 0.141000) # 二分検索(ループ)

748:デフォルトの名無しさん
08/10/29 05:57:19
>>746の二分検索は再帰で実装してあるけど、ループに展開すると
もうちょっと高速化できる。(ベンチ中のmatch_loopがそれ)
どうやって展開するのかは自分で考えてみてほしい。
うまく書ければ20行かそこらで済むはず。


ついでにおまけ。 (>>747続き、 match_なんたらはmatchと定義しておく)
def vlookup(val, range, column) # 指定列は0を起点とする
 val = val.to_f
 if val < range.first[0] or val > range.last[0]
  raise ArgumentError, "value out of range"
 end
 row = match val, range.map(&:first)
 # range[row][column] と同じだが、範囲外では例外を起こす。
 range[row].fetch column
end

pairs = lookup.zip(Array.new(lookup.size) { rand 100000 })
data.take(10).each do |v|
 puts vlookup(v, pairs, 1)
end


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

4712日前に更新/256 KB
担当:undef