![]() |
![]()
| ![]() |
![]()
NAMELingua::JA::Moji - Handle many kinds of Japanese characters SYNOPSISConvert romanised Japanese to and from kana: use utf8; use Lingua::JA::Moji qw/kana2romaji romaji2kana/; my $romaji = kana2romaji ('あいうえお'); print "$romaji\n"; my $kana = romaji2kana ($romaji); print "$kana\n"; produces output aiueo アイウエオ (This example is included as synopsis.pl <https://fastapi.metacpan.org/source/BKB/Lingua-JA-Moji-0.60/examples/synopsis.pl> in the distribution.) Convert between different forms of kana: use utf8; use Lingua::JA::Moji ':all'; my $h = 'あいうえおがっぷぴょん'; print kata2hira ($h), "\n"; print hira2kata (kata2hira ($h)), "\n"; print kana2hw ($h), "\n"; print kata2hira (hw2katakana (kana2hw ($h))), "\n"; # Silly circled kana print kana2circled ($h), "\n"; produces output あいうえおがっぷぴょん アイウエオガップピョン アイウエオガップピョン あいうえおがっぷぴょん ㋐㋑㋒㋓㋔㋕゛ッ㋫゜㋪゜ョン (This example is included as syn-kana.pl <https://fastapi.metacpan.org/source/BKB/Lingua-JA-Moji-0.60/examples/syn-kana.pl> in the distribution.) VERSIONThis document describes Lingua::JA::Moji version 0.60 corresponding to git commit 9ad3d6b5308d54f0c1eae61dc5bf7119c2670074 <https://github.com/benkasminbullock/Lingua-JA-Moji/commit/9ad3d6b5308d54f0c1eae61dc5bf7119c2670074> made on Wed Feb 14 15:11:13 2024 +0900. DESCRIPTIONThis module provides methods to convert different written forms of Japanese into one another. It enables conversion between romanized Japanese, hiragana, and katakana. It also includes a number of unusual encodings such as Japanese braille and morse code, as well as conversions between Japanese and Cyrillic and Hangul. It also handles conversion between the Chinese characters (kanji) used before and after the character reforms of 1949, as well as the various bracketed and circled forms of kana and kanji. All the functions in this module assume the use of Unicode encoding. All input and output strings must be encoded using Perl's "UTF-8" format. The module loads the various data format conversion files on demand, thus the various obscure conversions hopefully do not cause a memory burden. This module does not handle the conversion of kanji words into kana, or kana into kanji. ROMANIZATIONThese functions convert Japanese letters to and from romanized forms. is_romajiuse Lingua::JA::Moji 'is_romaji'; # The following line returns "undef" is_romaji ("abcdefg"); # The following line returns a defined value is_romaji ('loyehye'); # The following line returns a defined value is_romaji ("atarimae"); This detects whether a string of alphabetical characters, which may also include characters with macrons or circumflexes, "looks like" romanized Japanese. If the test is successful, it returns a true value, and if the test is unsuccessful, it returns a false value. If the string is empty, it returns a false value. Hyphens are not allowed as the first character. This works by converting the string to kana via "romaji2kana" and seeing if it converts cleanly or not. The "true" value returned is the output of the round-trip conversion, converted into wapuro format. is_romaji_semistrictuse Lingua::JA::Moji 'is_romaji_semistrict'; # The following line returns "undef" is_romaji_semistrict ("abcdefg"); # The following line returns "undef" is_romaji_semistrict ('loyehye'); # The following line returns a defined value is_romaji_semistrict ("atarimae"); # The following line returns a defined value is_romaji_semistrict ("pinku no dorufin"); Halfway between "is_romaji" and "is_romaji_strict", this allows some formations like "pinku no dorufin" but not the really unlikely stuff which "is_romaji" allows. is_romaji_strictuse Lingua::JA::Moji 'is_romaji_strict'; # The following line returns "undef" is_romaji_strict ("abcdefg"); # The following line returns "undef" is_romaji_strict ('loyehye'); # The following line returns a defined value is_romaji_strict ("atarimae"); This detects whether a string of alphabetical characters, which may also include characters with macrons or circumflexes, "looks like" romanized Japanese. If the test is successful, it returns a true value, and if the test is unsuccessful, it returns a false value. If the string is empty, it returns a false value. This test is much stricter than "is_romaji". It insists that the word does not contain constructions which may be valid as inputs to an IME, but which do not look like Japanese words. The "true" value returned is the output of the round-trip conversion, converted into wapuro format. This was added to the module in version "0.27". is_voiceduse Lingua::JA::Moji 'is_voiced'; if (is_voiced ('が')) { print "が is voiced.\n"; } Given a kana or romaji input, "is_voiced" returns a true value if the sound is a voiced sound like a, za, ga, etc. and the undefined value if not. kana2romajiConvert kana to romaji. use Lingua::JA::Moji 'kana2romaji'; $romaji = kana2romaji ("うれしいこども"); # $romaji = 'uresîkodomo' Convert kana to a romanized form. An optional second argument, a hash reference, controls the style of conversion. use utf8; $romaji = kana2romaji ("しんぶん", {style => "hepburn"}); # $romaji = "shimbun" The options are
kana_consonantuse Lingua::JA::Moji 'kana_consonant'; $consonant = kana_consonant ('ざる'); # $consonant = 's' Given a kana input, return the "dictionary order" consonant of the first kana. If the first kana is any of あいうえお, it returns an empty string. If the kana is an unvoiced kana, it returns the corresponding consonant of the first kana in the Nippon-shiki romanisation. If the kana is a voiced kana, it returns the corresponding consonant of the unvoiced version of the first kana in the Nippon-shiki romanisation. This enables Japanese words to be sorted into the order used in Japanese dictionaries, where the voiced/unvoiced distinction between, for example, za and sa, or ta and da, is ignored. normalize_romajiuse Lingua::JA::Moji 'normalize_romaji'; $normalized = normalize_romaji ('tsumuji'); "normalize_romaji" converts romanized Japanese to a canonical form, which is based on the Nippon-shiki romanization, but without representing long vowels using a circumflex. In the canonical form, sokuon (っ) characters are converted into the string "xtu". If there is kana in the input string, this will also be converted to romaji. "normalize_romaji" is for comparing two Japanese words which may be represented in different ways, for example in different romanization systems, to see if they refer to the same word despite the difference in writing. It does not provide a standardized or officially-sanctioned form of romanization. romaji2hiraganaConvert romaji to hiragana. use Lingua::JA::Moji 'romaji2hiragana'; $hiragana = romaji2hiragana ('babubo'); # $hiragana = 'ばぶぼ' Convert romanized Japanese into hiragana. This takes the same options as "romaji2kana". It also switches on the "wapuro" option, which uses long vowels with a kana rather than a "chouon". romaji2kanaConvert romaji to kana. use Lingua::JA::Moji 'romaji2kana'; $kana = romaji2kana ('yamaguti'); # $kana = 'ヤマグチ' Convert romanized Japanese to katakana. The romanization is highly liberal and will attempt to convert any romanization it sees into katakana. The rules of romanization are based on the behaviour of the Microsoft IME (input method editor). To convert romanized Japanese into hiragana, use "romaji2hiragana". An optional second argument to the function contains options in the form of a hash reference, $kana = romaji2kana ($romaji, {wapuro => 1}); Use an option "wapuro => 1" to convert long vowels into the equivalent kana rather than "chouon". $kana = romaji2kana ($romaji, {ime => 1}); Use the "ime => 1" option to approximate the behaviour of an IME. For example, input "gumma" becomes グッマ and input "onnna" becomes オンナ. Passport romaji ("Ohshimizu") is disallowed if this option is switched on. See also "is_romaji", "is_romaji_strict", and "is_romaji_semistrict" for validation of romanised Japanese inputs. romaji_stylesuse Lingua::JA::Moji 'romaji_styles'; my @styles = romaji_styles (); # Returns a true value romaji_styles ("hepburn"); # Returns the undefined value romaji_styles ("frogs"); Given an argument, this returns a true value if it is a known style of romanization. Without an argument, it returns a list of possible styles, as an array of hash references, with each hash reference containing the short name under the key "abbrev" and the full name under the key "full_name". romaji_vowel_stylesuse Lingua::JA::Moji 'romaji_vowel_styles'; Returns a list of valid styles of romaji vowels. KANAThese functions convert one form of kana into another. cleanup_kanause Lingua::JA::Moji 'cleanup_kana'; This function converts any of hiragana, halfwidth katakana, or romaji input into katakana. It also converts various confusable kanji characters into kana. For example the "one" kanji 一 is converted into a "chouon", ー, and the "mouth" kanji 口 is converted into the katakana ロ (ro). This is used as the "front end" function for this katakana to English web application <https://www.sljfaq.org/cgi/k2e.cgi>. This was added to the module in version "0.46". hira2kataConvert hiragana to katakana. use Lingua::JA::Moji 'hira2kata'; $katakana = hira2kata ('ひらがな'); # $katakana = 'ヒラガナ' "hira2kata" converts hiragana into katakana. The input may be a single string or a list of strings. If the input is a list, it converts each element of the list, and in list context it returns a list of the converted inputs. In scalar context it returns a concatenation of the strings. my @katakana = hira2kata (@hiragana); This does not convert "chouon" signs. hw2katakanaConvert halfwidth katakana to katakana. use Lingua::JA::Moji 'hw2katakana'; $full_width = hw2katakana ('アイウカキギョウ。'); # $full_width = 'アイウカキギョウ。' "hw2katakana" converts "halfwidth katakana" and halfwidth Japanese punctuation to fullwidth katakana and fullwidth punctuation. Its function is similar to the Emacs command "japanese-zenkaku-region". For the opposite function, see kana2hw. InHankakuKatakanause Lingua::JA::Moji 'InHankakuKatakana'; use utf8; if ('ア' =~ /\p{InHankakuKatakana}/) { print "ア is half-width katakana\n"; } "InHankakuKatakana" is a character class for use in regular expressions with "\p" which can validate "halfwidth katakana". InKanause Lingua::JA::Moji 'InKana'; $is_kana = ('アイウエオ' =~ /^\p{InKana}+$/); # $is_kana = '1' A character class for use in regular expressions which matches all kana characters. This class catches meaningful combinations of hiragana, katakana, halfwidth katakana, circled katakana, and katakana combined words. It does not match the hentaigana characters of Unicode. This is a combination of the existing Perl character classes "Katakana", "InKatakana", and "InHiragana", minus unassigned characters, plus the "halfwidth katakana prolonged sound mark" (U+FF70) <ー> (chouon), the "halfwidth katakana voiced sound mark" (U+FF9E) <゙> ("dakuten") and the "halfwidth katakana semivoiced sound mark" (U+FF9F) <゚> ("handakuten"), minus '・', Unicode 30FB, "KATAKANA MIDDLE DOT". It is somewhat like the following: qr/\p{Katakana}|\p{InKatakana}|\p{InHiragana}|ー|゙|゚>/ except that the unassigned points which are matched by "\p{Katakana}" are not matched and KATAKANA MIDDLE DOT is not matched. is_hiraganause Lingua::JA::Moji 'is_hiragana'; This function returns a true value if its argument is a string of hiragana, and an undefined value if not. The entire string from beginning to end must all be kana for this to return true. The kana cannot include punctuation marks or "chouon". is_kanause Lingua::JA::Moji 'is_kana'; This function returns a true value if its argument is a string of kana, or an undefined value if not. The input cannot contain punctuation or "chouon". is_katakanause Lingua::JA::Moji 'is_katakana'; Returns a true value if the string is katakana. At the moment this doesn't do the half-width katakana or squared symbol katakana. is_smalluse Lingua::JA::Moji 'is_small'; $is_small = ('ぁ'); Returns a true value for small kana, kana which have a bigger version as well, such as ぁ and あ. join_sound_marksuse Lingua::JA::Moji 'join_sound_marks'; $joined = join_sound_marks ('か゛は゜つ゛'); # $joined = 'がぱづ' Join "dakuten" and "handakuten" (Unicode U+3099-U+309C) to kana where possible. Where they cannot be joined, strip them out. This only works on full width kana. The return value is the joined text. This was added to the module in version "0.53". kana2hwConvert kana to halfwidth katakana. use Lingua::JA::Moji 'kana2hw'; $half_width = kana2hw ('あいウカキぎょう。'); # $half_width = 'アイウカキギョウ。' "kana2hw" converts hiragana, katakana, and fullwidth Japanese punctuation to "halfwidth katakana" and halfwidth punctuation. Its function is similar to the Emacs command "japanese-hankaku-region". For the opposite function, see hw2katakana. See also "katakana2hw" for a function which only converts katakana. kana2katakanaConvert kana to katakana. use Lingua::JA::Moji 'kana2katakana'; This converts any of katakana, "halfwidth katakana", circled katakana and hiragana to full width katakana. It also joins "dakuten" and "handakuten" marks to kana where possible, or removes them, using "join_sound_marks". kana_to_largeuse Lingua::JA::Moji 'kana_to_large'; $large = kana_to_large ('ぁあぃい'); # $large = 'ああいい' Convert small-sized kana such as 「ぁ」 into full-sized kana such as 「あ」. kata2hiraConvert katakana to hiragana. use Lingua::JA::Moji 'kata2hira'; $hiragana = kata2hira ('カキクケコ'); # $hiragana = 'かきくけこ' "kata2hira" converts full-width katakana into hiragana. If the input is a list, it converts each element of the list, and in list context, returns a list of the converted inputs, otherwise it returns a concatenation of the strings. my @hiragana = hira2kata (@katakana); This function does not convert "chouon" signs into long vowels. It also does not convert half-width katakana into hiragana. katakana2hwConvert katakana to halfwidth katakana. use Lingua::JA::Moji 'katakana2hw'; $hw = katakana2hw ("あいうえおアイウエオ"); # $hw = 'あいうえおアイウエオ' This converts katakana to "halfwidth katakana", leaving hiragana unchanged. See also "kana2hw". katakana2squareuse Lingua::JA::Moji 'katakana2square'; $sq = katakana2square ('カロリーアイウエオウォン'); # $sq = '㌍アイウエオ㌆' Convert katakana into a square thing if possible. katakana2syllableuse Lingua::JA::Moji 'katakana2syllable'; $syllables = katakana2syllable ('ソーシャルブックマークサービス'); This breaks the given string into syllables. If the string is broken up character by character, it becomes 'ソ', 'ー', 'シ', 'ャ', 'ル'. However, by themselves, 'ー' and 'ャ' can't be spoken. This breaks the string up into pronouncable syllables, so that $syllables becomes 'ソー', 'シャ', 'ル'. A "syllabic n" is attached to the preceding sequence, so for example フラナガン is broken up into four syllables, フ, ラ, ナ, ガン. This routine is used as the basis of this Change your name to kanji web application <https://www.sljfaq.org/cgi/name-kanji.cgi>. The name is converted from English to kana, then this function is used to break the kana name into pieces to which a kanji may be attached. It's also used in this Katakana to English converter <https://www.sljfaq.org/cgi/k2e.cgi> for the case that no words can be matched, and suggestions are made for how to split the word into possible components. This was added to the module in version "0.24". nigori_firstuse Lingua::JA::Moji 'nigori_first'; my @list = (qw/カン スウ ハツ オオ/); nigori_first (\@list); # Now @list = (qw/カン スウ ハツ オオ ガン ズウ バツ パツ/); Given a list of kana, add all the possible versions of the words with the first kana with either a "dakuten" or a "handakuten" added. This was intended for a search for a particular kanji in a dictionary. It is not actually in use anywhere at the moment. This was added to the module in version "0.36". smallize_kanause Lingua::JA::Moji 'smallize_kana'; $smallize = smallize_kana ('オキヤクサマガカツタ'); # $smallize = 'オキャクサマガカッタ' Given katakana input, convert possible "old-style" kana usage with large kanas used for "youon" or "sokuon" into smaller kana. If the conversion succeeds, return the converted value, otherwise return the undefined value. (I found the undefined value works better as a return value on failure than returning the text itself, since it saves the user from having to check whether the text has changed.) The conversion is not intelligent, it just attempts to do as much as possible, so although it will work to convert "shiyotsuchiyuu" ("シヨツチユウ") into "shotchuu" ("ショッチュウ"), it will also do stupid things like converting "chiyoda" (ちよだ) into "choda" (ちょだ). This was added to the module in version "0.46". split_sound_marksuse Lingua::JA::Moji 'split_sound_marks'; $split = split_sound_marks ('ガパヅ'); # $split = 'カ゛ハ゜ツ゛' Split "dakuten" and "handakuten" from kana where possible. U+309B and U+309C are chosen rather than U+3099 and U+309A. (This choice was somewhat arbitrary. I'm not sure which of the pairs should be used. I chose these because they were the ones already in use internally in the module in "kana2braille" and "kana2morse".) This only works on full width kana. The return value is the split text. This was added to the module in version "0.53". square2katakanause Lingua::JA::Moji 'square2katakana'; $kata = square2katakana ('㌆'); # $kata = 'ウォン' Convert a square katakana box into its components. strip_sound_marksuse Lingua::JA::Moji 'strip_sound_marks'; Strip sound marks from kana, so that for example パン (katakana pan) becomes ハン (katakana han). This was added to the module in version "0.59". HENTAIGANAVariant kana forms. Hentaigana are new in Unicode 10.0 (June 2017). hentai2kanause Lingua::JA::Moji 'hentai2kana'; Convert hentaigana into hiragana. Hentaigana with multiple interpretations are converted into a list of kana separated by a middle dot character. This was added to the module in version "0.43". hentai2kanjiuse Lingua::JA::Moji 'hentai2kanji'; $kanji = hentai2kanji ('𛀢'); # $kanji = '家' Convert hentaigana into their equivalent kanji. This was added to the module in version "0.43". kana2hentaiuse Lingua::JA::Moji 'kana2hentai'; $hentai = kana2hentai ('ケンブ'); # $hentai = '𛀢・𛀲・𛀳・𛀴・𛀵・𛀶・𛀷𛄝・𛄞𛂰・𛂱・𛂲゛' Convert kana to equivalent hentaigana. If more than one hentaigana exists, they are returned joined with a middle dot. The "dakuten" and "handakuten" are split out of the kana using "split_sound_marks" before the conversion. This was added to the module in version "0.43". kanji2hentaiuse Lingua::JA::Moji 'kanji2hentai'; $kanji = kanji2hentai ('家'); # $kanji = '𛀢' Convert kanji to equivalent hentaigana, where they exist. This was added to the module in version "0.43". WIDE ASCII FUNCTIONSFunctions for handling "wide ASCII". ascii2wideConvert printable ASCII characters to wide ASCII characters. use Lingua::JA::Moji 'ascii2wide'; $wide = ascii2wide ('abCE019'); # $wide = 'abCE019' Convert ASCII into "wide ASCII". It also converts the ASCII space, ASCII 0x20 into a fullwidth space, "U+3000". InWideAsciiuse Lingua::JA::Moji 'InWideAscii'; use utf8; if ('A' =~ /\p{InWideAscii}/) { print "A is wide ascii\n"; } This is a character class for use with \p which matches "wide ASCII". It also matches the fullwidth space, "U+3000". wide2asciiConvert wide ASCII characters to printable ASCII characters. use Lingua::JA::Moji 'wide2ascii'; $ascii = wide2ascii ('abCE019'); # $ascii = 'abCE019' Convert "wide ASCII" into ASCII. It also converts the fullwidth space, "U+3000", into an ASCII space, ASCII 0x20. OTHER TYPES OF LETTERINGbraille2kanaConvert Japanese braille to kana. use Lingua::JA::Moji 'braille2kana'; Converts Japanese braille (tenji) into the equivalent katakana. circled2kanaConvert circled katakana to kana. use Lingua::JA::Moji 'circled2kana'; $kana = circled2kana ('㋐㋑㋒㋓㋔'); # $kana = 'アイウエオ' This function converts the "circled katakana" of Unicode into full-width katakana. See also "kana2circled". kana2brailleConvert kana to Japanese braille. use Lingua::JA::Moji 'kana2braille'; This converts kana into the equivalent Japanese braille (tenji) forms. Bugs This is not an adequate Japanese braille converter. Creating Japanese braille requires breaking Japanese sentences up into individual words, but this does not attempt to do that. People who are interested in building a Perl braille converter could start here. kana2circledConvert kana to circled katakana. use Lingua::JA::Moji 'kana2circled'; $circled = kana2circled ('アイウエオガン'); # $circled = '㋐㋑㋒㋓㋔㋕゛ン' This function converts kana into the "circled katakana" of Unicode, which have code points from 32D0 to 32FE. See also "circled2kana". There is no circled form of the ン kana, "syllabic n", so this is left untouched. The "dakuten" and "handakuten" are split from the kana using "split_sound_marks". Circled katakana appear as Unicode code points U+32D0 to U+32FE. kana2morseConvert kana to Japanese morse code (wabun code). use Lingua::JA::Moji 'kana2morse'; $morse = kana2morse ('ショッチュウ'); # $morse = '--.-. -- .--. ..-. -..-- ..-' Convert Japanese kana into Morse code. Japanese morse code does not have any way of representing small kana characters, so converting to and then from morse code will result in ショッチュウ becoming シヨツチユウ. The function "smallize_kana" may work to fix these outputs in some cases. morse2kanaConvert Japanese morse code (wabun code) to kana. use Lingua::JA::Moji 'morse2kana'; $kana = morse2kana ('--.-. -- .--. ..-. -..-- ..-'); # $kana = 'シヨツチユウ' Convert Japanese Morse code into kana. Each Morse code element must be separated by whitespace from the next one. KANJIbad_kanjiuse Lingua::JA::Moji 'bad_kanji'; my @bad_kanji = bad_kanji (); Returns a list of kanji with negative meanings. See also <https://www.lemoda.net/japanese/offensive-kanji/index.html>. This was added to the module in version "0.47". bracketed2kanjiuse Lingua::JA::Moji 'bracketed2kanji'; $kanji = bracketed2kanji ('㈱'); # $kanji = '株' Convert bracketed form of kanji into unbracketed form. circled2kanjiuse Lingua::JA::Moji 'circled2kanji'; $kanji = circled2kanji ('㊯'); # $kanji = '協' Convert the circled forms of kanji into their uncircled equivalents. kanji2bracketeduse Lingua::JA::Moji 'kanji2bracketed'; $kanji = kanji2bracketed ('株'); # $kanji = '㈱' Convert an unbracketed form of kanji into bracketed form, if it exists, otherwise do nothing with it. kanji2circleduse Lingua::JA::Moji 'kanji2circled'; $kanji = kanji2circled ('協嬉'); # $kanji = '㊯嬉' Convert the usual forms of kanji into circled equivalents, if they exist. Note that only a limited number of kanji have circled forms. new2old_kanjiConvert Modern kanji to Pre-1949 kanji. use Lingua::JA::Moji 'new2old_kanji'; $old = new2old_kanji ('三国 連太郎'); # $old = '三國 連太郎' Convert new-style (post-1949) kanji (Chinese characters) into old-style (pre-1949) kanji. Bugs The list of characters in this converter may not contain every pair of old/new kanji. It will not correctly convert 弁 since this has three different equivalents in the old system. old2new_kanjiConvert Pre-1949 kanji to Modern kanji. use Lingua::JA::Moji 'old2new_kanji'; $new = old2new_kanji ('櫻井'); # $new = '桜井' Convert old-style (pre-1949) kanji (Chinese characters) into new-style (post-1949) kanji. yurei_mojiuse Lingua::JA::Moji 'yurei_moji'; my @yurei = yurei_moji (); Returns a list of the yurei moji (幽霊文字), kanji which don't actually exist but were mistakenly included in a computer standard. See <https://www.sljfaq.org/afaq/yuureimoji.html> for more information. This was added to the module in version "0.47". CYRILLIZATIONThis is an experimental cyrillization of kana based on the information in a Wikipedia article, <http://en.wikipedia.org/wiki/Cyrillization_of_Japanese>. The module author does not know anything about cyrillization of kana, so any assistance in correcting this is very welcome. cyrillic2katakanaConvert the Cyrillic (Russian) alphabet to katakana. use Lingua::JA::Moji 'cyrillic2katakana'; $kana = cyrillic2katakana ('симбун'); # $kana = 'シンブン' kana2cyrillicConvert kana to the Cyrillic (Russian) alphabet. use Lingua::JA::Moji 'kana2cyrillic'; $cyril = kana2cyrillic ('シンブン'); # $cyril = 'симбун' HANGUL (KOREAN LETTERS)kana2hanguluse Lingua::JA::Moji 'kana2hangul'; $hangul = kana2hangul ('すごわざ'); # $hangul = '스고와자' Bugs
SEE ALSOOther Perl modules on CPAN include Japanese kana/romanization
Kana/kanji conversion
Related modules
BooksParts of this module are covered in the book "Perl CPAN Module Guide" by Naoki Tomita (in Japanese), ISBN 978-4862671080, published by WEB+DB PRESS plus, April 2011. NOTESThis section explains some of the Japanese-language-specific terminology used elsewhere in the documentation. The headers in this section are in lower case for the benefit of internal documentation links. The explanatory links here go to the "sci.lang.japan Frequently Asked Questions", a Usenet FAQ about Japanese language.
EXPORTThis module exports its functions only on request. To export all the functions in the module, use Lingua::JA::Moji ':all'; DEPENDENCIES
ACKNOWLEDGEMENTSThanks to Naoki Tomita, David Steinbrunner, and Neil Bowers for fixes. HISTORY"Moji" (文字) means "letters" in Japanese. I started Lingua::JA::Moji out of a need for more comprehensive handling of Japanese text than was offered by any of the existing modules on CPAN. There were a lot of modules offering piecemeal romaji/kana conversions or hiragana/katakana conversions, but nothing comprehensive or robust. Lingua::JA::Moji was originally a private module. Most of the functions in the module are things I needed for my own projects. The design using Convert::Moji was part of an abandoned plan to make a cross-language module which could produce, say, a JavaScript converter doing the same things as this Perl one, using the same text sources. I wasn't really sure whether to release it, but eventually I released it to CPAN as a result of requests for the source code of an online romaji/kana converter by website users. The module interface, in particular the hash reference options to "kana2romaji" and "romaji2kana", is rather messy, and some of the defaults are rather strange, but since it was described in Naoki Tomita's book, and some people may be using it as is, I'm not very keen to change it in incompatible ways.
AUTHORBen Bullock, <bkb@cpan.org> COPYRIGHT & LICENCEThis package and associated files are copyright (C) 2008-2024 Ben Bullock. You can use, copy, modify and redistribute this package and associated files under the Perl Artistic Licence or the GNU General Public Licence.
|