2011-10-07 38 views
10

文字列分割関数があるのでしょうか?次のようなもの:文字列分割関数

> (string-split "19 2.14 + 4.5 2 4.3/- *") 
'("19" "2.14" "+" "4.5" "2" "4.3" "/" "-" "*") 

私はそれを見つけられず、自分自身を作成し​​ました。私は時々スキームを使用するので、あなたがそれを修正し、よりよい解決法を提案すれば、私は感謝するでしょう:

#lang racket 

(define expression "19 2.14 + 4.5 2 4.3/- *") 

(define (string-split str) 

    (define (char->string c) 
    (make-string 1 c)) 

    (define (string-first-char str) 
    (string-ref str 0)) 

    (define (string-first str) 
    (char->string (string-ref str 0))) 

    (define (string-rest str) 
    (substring str 1 (string-length str))) 

    (define (string-split-helper str chunk lst) 
    (cond 
    [(string=? str "") (reverse (cons chunk lst))] 
    [else 
    (cond 
     [(char=? (string-first-char str) #\space) (string-split-helper (string-rest str) "" (cons chunk lst))] 
     [else 
     (string-split-helper (string-rest str) (string-append chunk (string-first str)) lst)] 
     ) 
    ] 
    ) 
) 

    (string-split-helper str "" empty) 
) 

(string-split expression) 
+3

の一部です。これはCではありません:) – erjiang

+2

いいえ、何でも好きなことをする必要があります。 – rightfold

答えて

13

Oh my!それはたくさんの仕事です。私が正しくあなたの問題を理解していれば、私はこのために正規表現分割を使用します。

 
#lang racket 
(regexp-split #px" " "bc thtn odnth") 

=>、私はirregex卵を使用したチキンスキームでこれをやっただけで、他のSchemersのための基準として

 
Language: racket; memory limit: 256 MB. 
'("bc" "thtn" "odnth") 
+3

通常、 '#px" + "'や '#px" [[:space:]] "'のようなものが適切です。 (意図があった場合) –

6

(use irregex) 

(define split-regex 
    (irregex '(+ whitespace))) 

(define (split-line line) 
    (irregex-split split-regex line)) 

(split-line "19 2.14 + 4.5 2 4.3/- *") => 
("19" "2.14" "+" "4.5" "2" "4.3" "/" "-" "*") 
+1

毎回その定義をコピーしたくない場合、 '(string-split)'は 'coops'の卵の一部でもあります。残念ながら、それはdocページには書かれていません。 – user1610406