[#30920] [REQ] Regexp#match! — Minero Aoki <aamine@...>

あおきです。

19 messages 2001/08/16

[#30945] file exist check method? — "Inoue" <inoue@...>

井上です。

98 messages 2001/08/17
[#30947] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/17

こんにちは、なかむら(う)です。

[#30949] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/17

新井です。

[#30950] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/17

こんにちは、なかむら(う)です。

[#30951] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/17

新井です。

[#30953] Re: file exist check method? — nobu.nakada@... 2001/08/17

なかだです。

[#30954] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/17

新井です。

[#30955] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/17

こんにちは、なかむら(う)です。

[#30956] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/17

新井です。

[#30958] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/18

こんにちは、なかむら(う)です。

[#30962] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/18

新井です。

[#30963] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/18

こんにちは、なかむら(う)です。

[#30965] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/18

新井です。

[#30969] Re: file exist check method? — nobu.nakada@... 2001/08/18

なかだです。

[#30970] Re: file exist check method? — Koji Arai <JCA02266@...> 2001/08/18

新井です。

[#30981] Re: file exist check method? — Kazuhiro Yoshida <moriq.kazuhiro@...> 2001/08/18

もりきゅうです。長文ごめんなさい。

[#30983] Re: file exist check method? — IWATSUKI Hiroyuki <don@...> 2001/08/18

岩月と申します。そろそろ寝なくては。

[#30988] Re: file exist check method? — Kazuhiro Yoshida <moriq.kazuhiro@...> 2001/08/19

もりきゅうです。

[#30989] Re: file exist check method? — Kazuhiro Yoshida <moriq.kazuhiro@...> 2001/08/19

もりきゅうです。

[#30997] Re: file exist check method? — nobu.nakada@... 2001/08/19

なかだです。

[#31020] Re: file exist check method? — Kazuhiro Yoshida <moriq.kazuhiro@...> 2001/08/20

もりきゅうです。

[#31022] Re: file exist check method? — maili31s@... (SugHimsi == SUGIHARA Hiroshi) 2001/08/20

すぎむし。

[#31024] Re: file exist check method? — nobu.nakada@... 2001/08/20

なかだです。

[#31025] File#join — Kazuhiro Yoshida <moriq.kazuhiro@...> 2001/08/20

もりきゅうです。subject 変えました。

[#31029] Re: File#join — Kazuhiro NISHIYAMA <zn@...> 2001/08/21

In <200108201823.AA00825@yoshida.nifty.ne.jp>

[#31079] Re: File#join — "K.Umakoshi" <pegacorn@...> 2001/08/22

File#join とか File#split とか使った事ないんですが…

[#31062] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/21

こんにちは、なかむら(う)です。

[#31065] Re: file exist check method? — nobu.nakada@... 2001/08/22

なかだです。

[#31067] Re: file exist check method? — Kazuhiro Yoshida <moriq.kazuhiro@...> 2001/08/22

もりきゅうです。

[#31068] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/22

こんにちは、なかむら(う)です。

[#31073] Re: file exist check method? — nobu.nakada@... 2001/08/22

なかだです。

[#31082] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/22

こんにちは、なかむら(う)です。

[#31087] Re: file exist check method? — nobu.nakada@... 2001/08/23

なかだです。

[#31094] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/23

こんにちは、なかむら(う)です。

[#31096] Re: file exist check method? — "U.Nakamura" <usa@...> 2001/08/23

こんにちは、なかむら(う)です。

[#31005] インストールしました — 嶋崎 正貴 <hayashih@...>

嶋崎と申します

15 messages 2001/08/20

[#31144] create_process または Win での外部コマンド実行 — Take_tk <ggb03124@...>

Windows で外部コマンドを実行するにはどういう方法があるのでしょうか?。

33 messages 2001/08/29
[#31145] Re: create_process または Win での外部コマンド実行 — "U.Nakamura" <usa@...> 2001/08/29

こんにちは、なかむら(う)です。

[#31152] Re: create_process または Win での外部コマンド実行 — nobu.nakada@... 2001/08/29

なかだです。

[#31153] Re: create_process または Win での外部コマンド実行 — Take_tk <ggb03124@...> 2001/08/29

たけ(tk)です。

[ruby-list:30987] [REQ] String#slice(re, n)

From: Minero Aoki <aamine@...>
Date: 2001-08-19 03:22:50 UTC
List: ruby-list #30987
あおきです。

Regexp#match! のスレッドにおつきあいくださったみなさん、どうも
ありがとうございました。反論に対していろいろ考えているうちに
もともとやりたかったこと、気にくわなかったことがより鮮明になって
きたので、今度は別の提案です。

Regexp#match! を提案する原因になったのはそもそも

    m = re.match(str) or raise ....
    m[1]

と書くときにローカル変数を使うのがイヤ、ということでしたが、
もしかしたらこの形を使うという前提がよくなかったんではないかと
思いはじめました。というのは、本当にやりたいことが

    正規表現にマッチする部分文字列の取り出し

であるのに対して

    1. match して
    2. MatchData をもらって
    3. インデクシングで結果を取る

というやりかたがそもそもまどろっこしいというか、間接的にすぎる。
また単にローカル変数を使わないといけない、ということではなく、
MatchData というなんか正体の見えない中間結果をローカル変数に
入れなきゃいけない、というのが納得いかない点でした。


そこでもっと直接的に「正規表現を使った部分文字列の取り出し」を
するメソッドがあればいいのではないか、と考えました。一方あらためて
メソッドをながめてみると、すでに String#slice(re) で文字列から
正規表現にマッチした部分を取り出すことができます。これを拡張して

: slice(re, n=0)
    re の n 番目のレジスタにマッチした部分を返す。

とするのはどうでしょうか。そうすると

    cname = str.slice(re, 1) or raise ....

みたいに書けて、少なくとも中間ローカル変数には意味のある値を入れ
られるし、その値で分岐するんだったら納得がいきます。


もちろん既存のメソッドを使っても

    cname = re.match(str).to_a[1] or raise ....

とすることはできます。しかしこれでは間接的すぎるのがイヤです。
そもそも MatchData というもの自体が「マッチという主作用にくっ
ついてくる副作用」という感覚があるので、さらにそこから to_a
なんて抽象化層をかませてしまうと非常に感覚から乖離してしまいます。
一言で言うと、やっていることをイメージできないんです。だから
これではイヤです。付け加えると、str がでかい場合には to_a で
巨大な文字列が生成されてメモリも無駄です。


(以下蛇足)

== 「機能はいいが名前がよくない」と言われた場合に備えた追加

現在 slice には二つの機能があると思います。ひとつはインデックス
によるスライス、ふたつめは中身によるスライスです。

  * インデックスによるスライス
      str.slice(n)
      str.slice(start,len)
      str.slice(begin..end)

  * 中身によるスライス
      str.slice(substr)
      str.slice(re)

これをひとつのメソッドで行っているのがそもそも過剰と思えるので、
slice がやるのはインデックスによるスライスだけにとどめ、中身に
よるスライスは別のメソッドにします。たとえば extract とか matched
とか……。んで、[] (aref) にはユーティリティとして両方の機能を
持たせます。


== [追加提案] 一度に複数の部分マッチを取る

取りたい部分マッチがひとつではないことも多いと思います。それに
備えてインデックス部分に配列を渡せるようにするのはどうでしょう。

  # 例
  substr1, substr2, substr3 = str.slice(re, [n1, n2, n3])

これは

  a = re.match(str).to_a.indexes(n1, n2, n3)

に相当します。が、こっちはすごく欲しいというほどではないです。
あれば便利かなあ、くらい (多重代入だから条件式に使えないし)。


== think also?

ずっと前から何回も出てくる「一回しか scan しない scan」をもう
一度考えるいい機会かもしれない。機能的に似ている。
-------------------------------------------------------------------
青木峰郎

In This Thread

Prev Next