Commit | Line | Data |
---|---|---|
5a310f9b | 1 | =encoding utf8 |
a5921eb1 | 2 | |
d8416318 JH |
3 | =head1 NAME |
4 | ||
5a310f9b | 5 | perljp - 日本語 Perl ガイド |
d8416318 | 6 | |
5a310f9b | 7 | =head1 説明 |
d8416318 | 8 | |
5a310f9b | 9 | Perl の世界へようこそ! |
d8416318 | 10 | |
5a310f9b | 11 | Perl 5.8.0 より、Unicodeサポートが大幅に強化され、その結果ラテン文字以外の文字コードのサポートが CJK (中国語、日本語、ハングル)を含めて加わりました。Unicodeは世界中の文字を一つの文字コードで扱うことを目指した標準規格であり、東から西、はたまたその間の文字(ギリシャ文字、キリール文字、アラビア文字、ヘブライ文字、ディーヴァナガーリ文字、などなど)や、これまではOSベンダーが独自に定めていた文字(PCおよびMacintosh)がすでに含まれています。 |
d8416318 | 12 | |
5a310f9b | 13 | Perl 自身は Unicode で動作します。Perl スクリプト内の文字列リテラルや正規表現は Unicode を前提としています。そして入出力のためには、これまで使われてきたさまざまな文字コードに対応するモジュール、「 Encode 」が標準装備されており、Unicode とこれらの文字コードの相互変換も簡単に行えるようになっています。 |
d8416318 | 14 | |
5a310f9b | 15 | 現時点で Encode がサポートする文字コードは以下のとおりです。 |
d8416318 JH |
16 | |
17 | 7bit-jis AdobeStandardEncoding AdobeSymbol AdobeZdingbat | |
18 | ascii big5 big5-hkscs cp1006 | |
19 | cp1026 cp1047 cp1250 cp1251 | |
20 | cp1252 cp1253 cp1254 cp1255 | |
21 | cp1256 cp1257 cp1258 cp37 | |
22 | cp424 cp437 cp500 cp737 | |
23 | cp775 cp850 cp852 cp855 | |
24 | cp856 cp857 cp860 cp861 | |
25 | cp862 cp863 cp864 cp865 | |
26 | cp866 cp869 cp874 cp875 | |
27 | cp932 cp936 cp949 cp950 | |
28 | dingbats euc-cn euc-jp euc-kr | |
29 | gb12345-raw gb2312-raw gsm0338 hp-roman8 | |
30 | hz iso-2022-jp iso-2022-jp-1 iso-8859-1 | |
31 | iso-8859-10 iso-8859-11 iso-8859-13 iso-8859-14 | |
32 | iso-8859-15 iso-8859-16 iso-8859-2 iso-8859-3 | |
33 | iso-8859-4 iso-8859-5 iso-8859-6 iso-8859-7 | |
34 | iso-8859-8 iso-8859-9 iso-ir-165 jis0201-raw | |
35 | jis0208-raw jis0212-raw johab koi8-f | |
36 | koi8-r koi8-u ksc5601-raw MacArabic | |
37 | MacCentralEurRoman MacChineseSimp MacChineseTrad MacCroatian | |
38 | MacCyrillic MacDingbats MacFarsi MacGreek | |
39 | MacHebrew MacIcelandic MacJapanese MacKorean | |
40 | MacRoman MacRomanian MacRumanian MacSami | |
41 | MacSymbol MacThai MacTurkish MacUkrainian | |
42 | nextstep posix-bc shiftjis symbol | |
43 | UCS-2BE UCS-2LE UTF-16 UTF-16BE | |
44 | UTF-16LE UTF-32 UTF-32BE UTF-32LE | |
45 | utf8 viscii | |
46 | ||
5a310f9b | 47 | (全114種類) |
d8416318 | 48 | |
5a310f9b | 49 | 例えば、文字コードFOOのファイルをUTF-8に変換するには、以下のようにします。 |
d8416318 JH |
50 | |
51 | perl -Mencoding=FOO,STDOUT,utf8 -pe1 < file.FOO > file.utf8 | |
52 | ||
5a310f9b | 53 | また、Perlには、全部がPerlで書かれた文字コード変換ユーティリティ、piconvも付属しているので、以下のようにすることもできます。 |
d8416318 JH |
54 | |
55 | piconv -f FOO -t utf8 < file.FOO > file.utf8 | |
56 | piconv -f utf8 -t FOO < file.utf8 > file.FOO | |
57 | ||
119c5dc0 | 58 | =head2 (jcode.pl|Jcode.pm|JPerl) からの移行 |
d8416318 | 59 | |
4b05bc8e | 60 | 5.8以前の、スクリプトがEUC-JPであればリテラルだけは扱うことができました。また、入出力を扱うモジュールとしてはJcode.pmが( L<http://openlab.ring.gr.jp/Jcode/> )、perl4用のユーティリティとしてはjcode.plがそれぞれ存在し、日本語の扱えるCGIでよく利用されていることを御存じの方も少なくないかと思われます。ただし、日本語による正規表現をうまく扱うことは不可能でした。 |
d8416318 | 61 | |
119c5dc0 | 62 | 5.005以前のPerlには、日本語に特化したローカライズ版、Jperlが存在しました( L<http://homepage2.nifty.com/kipp/perl/jperl/index.html> ※1)。また、Mac OS 9.x/Classic用のPerl、MacPerlの日本語版もMacJPerlとして存在してました。( L<https://habilis.net/macjperl/> ).これらでは文字コードとしてEUC-JPに加えShift_JISもそのまま扱うことができ、また日本語による正規表現を扱うことも可能でした。 |
d8416318 | 63 | |
5a310f9b | 64 | Perl5.8では、これらの機能がすべてPerl本体だけで実現できる上に、日本語のみならず上記114の文字コードをすべて、しかも同時に扱うことができます。さらに、CPANなどから新しい文字コード用のモジュールを入手することも簡単にできるようになっています。 |
d8416318 | 65 | |
119c5dc0 IS |
66 | ※1: ホスティングサービスの終了により現在は閲覧できません。 Vector( L<https://www.vector.co.jp/soft/win95/util/se098198.html> )からWindow用のバイナリを、CPAN( L<https://www.cpan.org/src/unsupported/4.036/jperl/> )からperl4用のパッチを入手することができます。 |
67 | ||
d8416318 JH |
68 | =over 4 |
69 | ||
fe30b7f4 JH |
70 | =item * |
71 | ||
5a310f9b | 72 | 入出力 |
d8416318 | 73 | |
119c5dc0 | 74 | 以下の例はいずれもShift_JISの入力をEUC-JPに変換して出力します。 |
d8416318 JH |
75 | |
76 | # jcode.pl | |
77 | require "jcode.pl"; | |
78 | while(<>){ | |
1d587bbd | 79 | jcode::convert(*_, 'euc', 'sjis'); |
d8416318 JH |
80 | print; |
81 | } | |
82 | # Jcode.pm | |
83 | use Jcode; | |
84 | while(<>){ | |
85 | print Jcode->new($_, 'sjis')->euc; | |
86 | } | |
87 | # Perl 5.8 | |
88 | use Encode; | |
89 | while(<>){ | |
90 | from_to($_, 'shiftjis', 'euc-jp'); | |
91 | print; | |
92 | } | |
5a310f9b | 93 | # Perl 5.8 - encoding を利用して |
1d587bbd | 94 | use encoding 'euc-jp', STDIN => 'shiftjis'; |
d8416318 JH |
95 | while(<>){ |
96 | print; | |
97 | } | |
98 | ||
fe30b7f4 JH |
99 | =item * |
100 | ||
5a310f9b | 101 | Jperl 互換スクリプト |
d8416318 | 102 | |
5a310f9b | 103 | いわゆる"shebang"を変更するだけで、Jperl用のscriptのほとんどは変更なしに利用可能だと思われます。 |
818c4caa | 104 | |
d8416318 | 105 | #!/path/to/jperl |
5a310f9b | 106 | ↓ |
d8416318 | 107 | #!/path/to/perl -Mencoding=euc-jp |
818c4caa | 108 | |
5a310f9b | 109 | 詳しくは perldoc encoding を参照してください。 |
d8416318 JH |
110 | |
111 | =back | |
112 | ||
5a310f9b | 113 | =head2 さらに詳しく |
d8416318 | 114 | |
5a310f9b | 115 | Perlには膨大な資料が付属しており、Perlの新機能やUnicodeサポート、そしてEncodeモジュールの使用法などが細かく網羅されています(残念ながら、ほとんど英語ではありますが)。以下のコマンドでそれらの一部を閲覧することが可能です。 |
d8416318 | 116 | |
5a310f9b LT |
117 | perldoc perlunicode # PerlのUnicodeサポート全般 |
118 | perldoc Encode # Encodeモジュールに関して | |
119 | perldoc Encode::JP # うち日本語文字コードに関して | |
d8416318 | 120 | |
5a310f9b | 121 | =head2 Perl全般に関する URL |
d8416318 JH |
122 | |
123 | =over 4 | |
124 | ||
fdee78a1 | 125 | =item L<https://www.perl.org/> |
d8416318 | 126 | |
fdee78a1 | 127 | Perl ホームページ |
d8416318 | 128 | |
fdee78a1 KL |
129 | =item L<https://www.perl.com/> |
130 | ||
131 | Perl 財団が営業する文章作品集 | |
132 | ||
133 | =item L<https://www.cpan.org/> | |
d8416318 JH |
134 | |
135 | CPAN (Comprehensive Perl Archive Network) | |
136 | ||
119c5dc0 IS |
137 | =item L<https://metacpan.org/> |
138 | ||
139 | MetaCPAN CPANの検索エンジン | |
140 | ||
fdee78a1 | 141 | =item L<https://lists.perl.org/> |
d8416318 | 142 | |
5a310f9b | 143 | Perl メーリングリスト集 |
d8416318 | 144 | |
119c5dc0 IS |
145 | =item L<https://perldoc.jp/> |
146 | ||
147 | perldoc.jp Perl の公式ドキュメント、モジュールドキュメントの日本語訳 | |
148 | ||
d8416318 JH |
149 | =back |
150 | ||
5a310f9b | 151 | =head2 Perlの修得に役立つ URL |
d8416318 JH |
152 | |
153 | =over 4 | |
154 | ||
e59066d8 | 155 | =item L<http://www.oreilly.com.tw/> |
d8416318 | 156 | |
5a310f9b | 157 | O'Reilly 社のPerl関連書籍(繁体字中国語) |
d8416318 | 158 | |
e59066d8 | 159 | =item L<http://www.oreilly.com.cn/> |
d8416318 | 160 | |
5a310f9b | 161 | O'Reilly 社のPerl関連書籍(簡体字中国語) |
d8416318 | 162 | |
fdee78a1 | 163 | =item L<https://www.oreilly.co.jp/catalog/> |
d8416318 | 164 | |
5a310f9b | 165 | オライリー社のPerl関連書籍(日本語) |
d8416318 JH |
166 | |
167 | =back | |
168 | ||
119c5dc0 | 169 | =head2 Perl に関する団体 |
d8416318 JH |
170 | |
171 | =over 4 | |
172 | ||
fdee78a1 | 173 | =item L<https://www.pm.org/groups/asia.html> |
d8416318 | 174 | |
119c5dc0 IS |
175 | アジア地域の Perl Mongers (Perlのユーザーグループ) 一覧 |
176 | ||
177 | =item L<https://japan.perlassociation.org> | |
178 | ||
179 | 一般社団法人Japan Perl Association (JPA) Perl技術及び文化の啓蒙・促進のための組織 | |
180 | ||
d8416318 JH |
181 | =back |
182 | ||
5a310f9b | 183 | =head2 Unicode関連のURL |
d8416318 JH |
184 | |
185 | =over 4 | |
186 | ||
fdee78a1 | 187 | =item L<https://www.unicode.org/> |
d8416318 | 188 | |
5a310f9b | 189 | Unicode コンソーシアム (Unicode規格の選定団体) |
d8416318 | 190 | |
fdee78a1 | 191 | =item L<https://www.cl.cam.ac.uk/%7Emgk25/unicode.html> |
d8416318 JH |
192 | |
193 | UTF-8 and Unicode FAQ for Unix/Linux | |
194 | ||
fdee78a1 | 195 | =item L<https://wiki.kldp.org/Translations/html/UTF8-Unicode-KLDP/UTF8-Unicode-KLDP.html> |
d8416318 | 196 | |
5a310f9b | 197 | UTF-8 and Unicode FAQ for Unix/Linux (ハングル訳) |
d8416318 JH |
198 | |
199 | =back | |
200 | ||
201 | =head1 AUTHORS | |
202 | ||
119c5dc0 IS |
203 | =over |
204 | ||
205 | =item * Jarkko Hietaniemi E<lt>jhi@iki.fiE<gt> | |
206 | ||
207 | =item * Dan Kogai (小飼 弾) E<lt>dankogai@dan.co.jpE<gt> | |
208 | ||
209 | =item * Shogo Ichinose (一野瀬 翔吾) E<lt>shogo82148@gmail.comE<gt> | |
210 | ||
211 | =back | |
d8416318 JH |
212 | |
213 | =cut |