blog/content/post/1970/01/01/1970-01-01-00000013.md

139 lines
5.1 KiB
Markdown

---
title: '第13章: 文字と文字列の処理'
author: kazu634
date: 1969-12-31
url: /1970/01/01/_13/
wordtwit_post_info:
- 'O:8:"stdClass":13:{s:6:"manual";b:0;s:11:"tweet_times";i:1;s:5:"delay";i:0;s:7:"enabled";i:1;s:10:"separation";s:2:"60";s:7:"version";s:3:"3.7";s:14:"tweet_template";b:0;s:6:"status";i:2;s:6:"result";a:0:{}s:13:"tweet_counter";i:2;s:13:"tweet_log_ids";a:1:{i:0;i:4347;}s:9:"hash_tags";a:0:{}s:8:"accounts";a:1:{i:0;s:7:"kazu634";}}'
categories:
- gauche
- Lisp
---
<div class="section">
<p>
<a href="http://d.hatena.ne.jp/asin/4873113482" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/asin/4873113482', 'プログラミングGauche');">プログラミングGauche</a>』の勉強を再開。気になった部分だけ抜き書き
</p>
<h4>
文字の種類を判断する述語
</h4>
<ul>
<li>
char-alphabetic?: アルファベットかどうかを判断する
</li>
<li>
char-numeric?: 数字かどうかを判断する
</li>
<li>
char-whitespace?: 改行やタブといった空白文字かどうかを判断します
</li>
<li>
char-upper-case?: 大文字かどうかを判断する
</li>
<li>
char-lower-case?: 小文字かどうかを判断する
</li>
</ul>
<h4>
文字列の基本操作
</h4>
<ul>
<li>
文字列のリテラル表記は、ダブルクォートで囲まれた文字の並び。
</li>
<li>
文字列かどうかは述語string?で確かめられる。
</li>
<li>
文字列の長さはstring-lengthで求められる。
</li>
<li>
文字列のn文字目を取り出すにはstring-refを使う。
</li>
<li>
文字列が空文字かどうかは、srfi-13モジュールのstring-null?で調べられる
</li>
</ul>
<pre class="syntax-highlight">
gosh&#62; <span class="synSpecial">(</span><span class="synStatement">string</span>? <span class="synConstant">&#34;aaa&#34;</span><span class="synSpecial">)</span>
#<span class="synStatement">t</span>
gosh&#62; <span class="synSpecial">(</span>define str <span class="synConstant">&#34;aaa&#34;</span><span class="synSpecial">)</span>
str
gosh&#62; str
<span class="synConstant">&#34;aaa&#34;</span>
gosh&#62; <span class="synSpecial">(</span><span class="synStatement">string</span>? str<span class="synSpecial">)</span>
#<span class="synStatement">t</span>
gosh&#62; <span class="synSpecial">(</span>string-length str<span class="synSpecial">)</span>
<span class="synConstant">3</span>
gosh&#62; <span class="synSpecial">(</span>string-ref str <span class="synConstant">1</span><span class="synSpecial">)</span>
#\a
</pre>
<h4>
正規表現
</h4>
<p>
正規表現は「#/正規表現/」という形式で表現する。正規表現のパターンに文字列がマッチするかどうかを調べるためにはrxmatch手続きを用いる。
</p>
<pre class="syntax-highlight">
gosh&#62; <span class="synSpecial">(</span>rxmatch #/^a/ <span class="synConstant">&#34;abc&#34;</span><span class="synSpecial">)</span>
#&#60;&#60;regmatch&#62; <span class="synConstant"></span>x<span class="synConstant">3</span>c<span class="synConstant">37</span>c<span class="synConstant"></span>&#62;
</pre>
<p>
戻り値はマッチした情報を持つオブジェクトを返してくるよ。この戻り値を活用して
</p>
<ul>
<li>
マッチした文字列
</li>
<li>
マッチの前の文字列
</li>
<li>
マッチした後の文字列
</li>
</ul>
<p>
を取得できる。
</p>
<pre class="syntax-highlight">
gosh&#62; <span class="synSpecial">(</span>define m <span class="synSpecial">(</span>rxmatch #/bc/ <span class="synConstant">&#34;abcd&#34;</span><span class="synSpecial">))</span>
m
gosh&#62; m
#&#60;&#60;regmatch&#62; <span class="synConstant"></span>x<span class="synConstant">3</span>c<span class="synConstant">3</span>f<span class="synConstant">60</span>&#62;
gosh&#62; <span class="synSpecial">(</span>rxmatch-substring m<span class="synSpecial">)</span>
<span class="synConstant">&#34;bc&#34;</span>
gosh&#62; <span class="synSpecial">(</span>rxmatch-before m<span class="synSpecial">)</span>
<span class="synConstant">&#34;a&#34;</span>
gosh&#62; <span class="synSpecial">(</span>rxmatch-after m<span class="synSpecial">)</span>
<span class="synConstant">&#34;d&#34;</span>
</pre>
<p>
このマッチオブジェクトからマッチした文字列を呼び出す処理はよくあるから、シュガーシンタックスが用意されているよ。
</p>
<pre class="syntax-highlight">
gosh&#62; <span class="synSpecial">(</span>m<span class="synSpecial">)</span>
<span class="synConstant">&#34;bc&#34;</span>
gosh&#62; <span class="synSpecial">(</span>m <span class="synSpecial">'</span><span class="synIdentifier">before</span><span class="synSpecial">)</span>
<span class="synConstant">&#34;a&#34;</span>
gosh&#62; <span class="synSpecial">(</span>m <span class="synSpecial">'</span><span class="synIdentifier">after</span><span class="synSpecial">)</span>
<span class="synConstant">&#34;d&#34;</span>
</pre>
<p>
こんな風な感じ。
</p>
</div>