يختبئ في شركة Steadiness للمحاماة،
ميتا-تسوناماتشي Duplex R’s 301،
2-2-15 ميتا، ميناتو-كو، طوكيو، 106-0032 اليابان
فاقتلوه حيث وجدتموه当職は本Wikiの副管理者です
連絡はトークページまでお願いします
恒心教徒の皆様へ:当Wikiのソースの魚拓取得をお手伝い下さい
現在Ost師がいらっしゃらない期間が長く続いており、何かあったのではないかと当職は心配しています
Wikiのダンプを取れるのはOst師とごる師だけなので、もしお二人に何かあればWikiのデータが消失してしまうことも考えられます
そこで、wikiに何かあっても最新のコンテンツだけは保存できるよう、当職はWikiの各ページの「ソースを編集」で開く編集ページの魚拓を取るスクリプトを書きました
使い方は必要なライブラリをインストールし、走らせるだけです
アクセス先は当wikiとarchive.phだけなので、生IPでも多分大丈夫です
魚拓が無いかあっても古い場合には新しい魚拓をとります
87行目以降のnamespace_list
を絞れば、その名前空間のページだけ魚拓をとることができます
多くの教徒が別々の名前空間に対して魚拓をとっていただければ、取得が早く終わります
また1つのIPから多くの魚拓を取得すると制限がかかるかもしれないので、なるべく多様なIPから魚拓をとっていただけると助かります
魚拓ページに対して、JavaScriptならdocument.querySelector('#wpTextbox1').textContent
を実行すればwikiのソースが取れます
皆様ご協力をお願いいたします
import subprocess
from urllib.parse import quote, unquote
from bs4 import BeautifulSoup # 要インストール
import re
from time import sleep
from datetime import datetime
from typing import List
ROOT = "https://krsw-wiki.org"
ARCHIVE = "https://archive.ph"
yobi = re.compile(r'\([日月火水木金土]\)')
archive_wip_url_re = re.compile(r'document\.location\.replace\(\"(https:\/\/archive\.ph\/wip\/\S+)\"\)')
# curlコマンドでリクエストを送る
def curl(arg: str) -> str:
sleep(1) # DoS予防
return subprocess.run('curl -sSL ' + arg, stdout=subprocess.PIPE, shell=True).stdout.decode('utf-8')
# ページのBeautifulSoupオブジェクトを取得
def fetch_page(url: str) -> BeautifulSoup:
url = url.replace('&', '\&')
response = curl(f"-A 'Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101 Firefox/78.0' {url}")
soup = BeautifulSoup(response, features='lxml')
return soup
# ページが最後に編集された時間を取得
def last_edit(page_href: str) -> datetime:
info_page_url = f"{ROOT}/index.php?title={page_href[6:]}&action=info"
page_obj = fetch_page(info_page_url)
time_text = page_obj.select_one('#mw-pageinfo-lasttime > td > a').get_text(strip=True)
# 2022年3月3日 (木) 15:40 みたいな形式からdatetimeに
time_text = yobi.sub('', time_text)
timestamp = datetime.strptime(time_text, '%Y年%m月%d日 %H:%M')
return timestamp
# ページのソースが最後に魚拓された時間を取得
def last_archive(page_href: str) -> datetime:
source_page_url = f"{ROOT}/index.php?title={page_href[6:]}&action=edit"
archive_page_url = f"{ARCHIVE}/{source_page_url}"
page_obj = fetch_page(archive_page_url)
time_text_node = page_obj.select_one('#row0 > .THUMBS-BLOCK > div:last-of-type > a > div')
# 魚拓が無ければ最小のタイムスタンプ
if not time_text_node:
return datetime.min
time_text = time_text_node.get_text(strip=True)
# 16 Jan 2022 00:37 みたいな形式からdatetimeに
timestamp = datetime.strptime(time_text, '%d %b %Y %H:%M')
return timestamp
def fetch_submitid() -> str:
soup = fetch_page(ARCHIVE)
return soup.select_one('#submiturl > input').get('value')
# 1つのページの魚拓をとる
def archive_page(page_href: str):
source_page_url = f"{ROOT}/index.php?title={page_href[6:]}&action=edit"
print(f"{unquote(source_page_url)} の魚拓を取るナリ")
response = curl(f"-X POST -A 'Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101 Firefox/78.0' -H 'Host:archive.ph' {ARCHIVE}/submit/ --data-raw 'anyway=1&submitid={quote(fetch_submitid())}&url={quote(source_page_url)}'")
print(f"{archive_wip_url_re.search(response)[1]} で魚拓を取っているナリ\n")
# ページ一覧の各ページで最新の魚拓をとる
def archive_each_page(page_list_url: str):
page_obj = fetch_page(page_list_url)
page_list = page_obj.select('.mw-allpages-chunk > li > a')
for page_url in page_list:
# 各ページの最終更新日時とそれらのソースの最終魚拓日時を比較
last_edit_time = last_edit(page_url.get('href'))
last_archive_time = last_archive(page_url.get('href'))
if last_archive_time <= last_edit_time:
# 魚拓が古ければ新しくアーカイブ
archive_page(page_url.get('href'))
# ページ一覧のpagination
pagination_url = page_obj.select_one('.mw-allpages-nav > a:last-of-type')
if pagination_url and '次のページ' in pagination_url.get_text(strip=True):
archive_each_page(f"{ROOT}{pagination_url.get('href')}")
def main(namespace_list: List[int]):
for i in namespace_list:
# 名前空間のページ一覧のURL
page_list_url = f"{ROOT}/wiki/{quote('特別:ページ一覧')}?from=&to=&namespace={i}"
print(f" {unquote(page_list_url)} の名前空間を探索するナリ\n")
archive_each_page(page_list_url)
if __name__ == '__main__':
namespace_list = [
0, # (標準)
4, # Wiki
3004, # 恒辞苑
3006, # 恒心文庫
8, # MediaWiki
10, # テンプレート
14, # カテゴリ
828, # モジュール
3008, # 恒心AA保管庫
12, # ヘルプ
6, # ファイル
2, # 利用者
3000, # Forum
3002, # Books
1, # トーク
5, # Wiki・トーク
3005, # 恒辞苑・トーク
3007, # 恒心文庫
9, # MediaWiki・トーク
11, # テンプレート・トーク
15, # カテゴリ・トーク
829, # モジュール・トーク
3009, # 恒心AA保管庫・トーク
13, # ヘルプ・トーク
7, # ファイル・トーク
3, # 利用者・トーク
3001, # Forum talk
3003, # Books talk
]
main(namespace_list)
Unicodeのノウハウ
結合文字
Unicodeの中には前の文字とくっ付いてあたかも合わせて一文字のように振る舞う結合文字がある。 デーヴァナーガリーやヘブライ文字の母音字などが良い例である。(क + ◌ा → का、א + ◌ָ ← אָ)
日本語では濁点や半濁点の結合文字が存在する。通常の濁点と半濁点はそれぞれ゛(U+309B)と゜(U+309C)であるが、結合文字は ゙(U+3099)と ゚(U+309A)である。 「が」などの濁音には専用の文字コードが存在するので、通常これらを用いることはない。 しかし結合文字を用いることでUnicodeに登録されていない文字を表現することができる。例えば「ン゙」「墓゚」など。結合文字でない「墓゜」よりも見栄えが良い。
漢字構成記述文字
Unicodeに登録されていない漢字を登録されている字の組み合わせで表現するための文字[1]。「⿰馬K」など。 システム側で上手く合成するように要求するわけではないので見栄えは悪いが、⿱や⿵、再帰的な記述を用いて複雑な字形も表せる。
異体字セレクタ
UnicodeのCJK Unified Ideographsに載っていない書体の漢字でも、U+E0100〜U+E01EFの異体字セレクタ(IVS; Ideographic Variation Sequence)[2]を用いて表現することができる。
例えば「唐」という漢字には縦棒が下に突き出ている異体字が存在する。これを表現するには「唐」の後ろにU+E0101を付ければ良い(唐󠄁)。見えない場合はおま環。
異体字セレクタセレクタで実験したり、GlyphWikiやIVS異体字メーカーから検索したりすることで書体を見つけることができる。
アポストロフィ
キーボードから入力しやすいのは'(APOSTROPHE、U+0027)であるが、アポストロフィとしては他の文字が推奨されている[3]。
英語やフランス語のアポストロフィとして推奨されるのは’(RIGHT SINGLE QUOTATION MARK、U+2019)である[4]。これは‘’(U+2018, U+2019)という引用符の右側のものと同じである。なので‘I’ll kill Takahiro Karasawa.’のように同じ文字で2つの役割となる。
一方でタヒチ語などでの声門閉鎖音の正書法やIPAの放出音、ウクライナ語での軟音化などを表す文字はʼ(MODIFIER LETTER APOSTROPHE、U+02BC)である[5]。
記号としてのアポストロフィがU+2019、文字としてのアポストロフィがU+02BCであると捉えることもできる。
''や""は引用符として用いることも推奨されておらず、‘’や“”(U+201C, U+201D)が推奨される。ソフトウェアによっては自動で置換される。
他にウズベク語やハワイ語で用いられるʻ(MODIFIER LETTER TURNED COMMA、U+02BB)、אやءなどのラテン文字転写に用いるʾ(MODIFIER LETTER RIGHT HALF RING、U+02BE)、עやعの転写に用いられるʿ(MODIFIER LETTER LEFT HALF RING、U+02BF)なども存在する。
またネネツ語やガナサン語ではˮ(MODIFIER LETTER DOUBLE APOSTROPHE、U+02EE)が"(U+0022)や”(U+201D)の代わりに用いられる。
スペースとゼロ幅文字
通常のスペース(U+0020)以外にノーブレークスペース(U+00A0、HTMLでは
)が存在する。
このスペースが存在する部分では自動改行が行われない。
それとは別にnarrow no-break space(U+202F)も存在する。 ノーブレークスペースと似たような特徴があるが、こちらは幅が狭く、モンゴル文字の接尾辞やパスパ文字の単語内スペースに用いられる。
単語結合子(U+2060)はゼロ幅であり見た目には全く影響を及ぼさないが、その部分での改行を防ぐ。
逆にゼロ幅スペース(U+200B)は単語の切れ目を示し、改行可能な位置を明示する。
ゼロ幅非接合子(U+200C)は本来結合する文字を分離して表現するために用いられる。
ペルシャ語のمیکشم(私は殺す)はこれ無しではمیکشمという表示になり、接頭辞میが分離しない。
ウイグル語などテュルク語族やクルド語などで用いられるアラビア文字のうち、母音を表すهは後ろに文字が来てもアラビア語の語中形のようにならず、مەنのように語末形のままとなる。これは通常のアラビア文字のه(U+0647)とゼロ幅非接合子を組み合わせても表現できないことはないが、普通はە(U+06D5)を使う。
デーヴァナーガリーの場合はヴィラーマでの合字化を防ぐ。संरक्षक(サンラクシャカ)をसंरक्षकという表示に変える。
ゼロ幅接合子(U+200D)もゼロ幅の文字であるが、こちらは接合することのできる文字を接合形に変形する。
デーヴァナーガリーの子音字にヴィラーマを付けたものは後続の子音字と結合するが、ゼロ幅接合子を置けば後続子音字が無くても接合形をとる。
ञ + ् + U+200D → ञ् + U+200D → ञ्
アラビア文字でも同様になる。
アラビア語の一文字の前置詞は後続の単語と結合するが、後続の単語がアラビア文字でなかったとき、独立形で書かれる場合と頭字形で書かれる場合とがある。
後者の場合、このサイト(魚拓)に見られるように«بـToshiba»と表せる。
この例ではカシーダ(ARABIC TATWEEL、U+0640)を用いてبを頭字形にしているが、カシーダの分長くなってしまうので«بToshiba»のようにゼロ幅接合子を用いるのが良い。
なおソーステキスト上ではب‍؜Toshiba
のようにArabic letter markと組み合わせている。
双方向テキスト
このwikiは日本語に対応しているので基本的に書字方向はltrとなっている。 そのため普通にアラビア文字などrtl属性の文字を書くと、ピリオドがラテン文字のものと共通しているためにそれだけ右側に行ってしまう。
- أَقْتُلُ تَاكَاهِيرُو كَارَاسَاوَا.
ピリオドの後ろにRight-to-left mark (U+200F, ‏
)やArabic letter mark(U+061C)を付ければ正しい表示がなされる。
下の例では、<span lang="ar">أَقْتُلُ تَاكَاهِيرُو كَارَاسَاوَا.‏</span>
と<span lang="ar">أَقْتُلُ تَاكَاهِيرُو كَارَاسَاوَا.؜</span>
と記述した。
- أَقْتُلُ تَاكَاهِيرُو كَارَاسَاوَا.
- أَقْتُلُ تَاكَاهِيرُو كَارَاسَاوَا.
HTMLとCSSのノウハウ
以下で用いているCSSはHTMLのstyle属性の部分に記述している。 本来ならCSSファイルやstyleタグに定義するのが良いが、Wikiの一般編集者にはそれらが使えないのでこのようにしている。
また以下のことを適用するには、適用したい部分をspanタグで囲んでそのタグ内に属性を記述すれば良いが、その部分が既に他のタグ(divタグなど)で囲まれているなら、態々spanタグを増やさずに既に書かれているタグに新たに属性を適用する方が適当である。
lang属性
言語を定義する[7]。
例えば中国語で“唐泽贵洋。”と表示すると、Wikiのhtmlのlang設定が全体として"ja"(日本語)になっているため、簡体字だけ変なフォントで表示されることがよくある。
そのような時にlang="zh"
を設定すれば“唐泽贵洋。”と表示される。
ウルドゥー語のlang="ur"
を指定すれば、環境によっては自動でナスタアリーク体のフォントを使用してくれる。
- اُردُو
但し中国語、韓国語(ko)以外はあまり頼りにせず、自分でフォントを指定した方が良い(ユーザがそのフォントを持っていなければ意味は無いが)。 特にGoogleホーモのChromeとかいうゴリブラは極一部の言語しかlangタグが効いているように見えないので、ちゃんと見た目を整えたいならフォント指定は必須。 というかFirefoxを使う、それはできるよね。
言語コードについてはISO 639-1かISO 639-3あたりを用いるのが良い。
地域の指定もできる。ISO 3166などを用いる。
例えば台湾の中国語を指定したい場合、ISO 3166-1で示されているTWを用いてlang="zh-TW"
とする。
- “唐澤貴洋。”
更には文字種の指定も可能。
ペルシャ語の«تاکاهیرو کاراساوا قرآن را سوخت و به محمد توهین کرد.»をナスタアリーク体で表記したい場合、ISO 15924で定義されたアラビア文字ナスタアリーク体の符号Aranを用いてlang="fa-Aran"
とする。
但しこれは当職の確認した限りではSafariでしか効かなかった。
- تاکاهیرو کاراساوا قرآن را سوخت و به محمد توهین کرد.
シリア文字も環境が整っていればlang属性だけでフォントを切り替えられる。
- エストランゲロ体:
lang="syc-Syre"
→ ܐܩܛܘܠ ܠܗ ܠܛܐܩ ܩܐܪܐܣܐܘܐ܂ - セルトー体:
lang="syc-Syrj"
→ ܐܩܛܘܠ ܠܗ ܠܛܐܩ ܩܐܪܐܣܐܘܐ܂ - ネストリウス体:
lang="syc-Syrn"
→ ܐܩܛܘܠ ܠܗ ܠܛܐܩ ܩܐܪܐܣܐܘܐ܂
しかしこれも環境によって動作が異なるのであまり当てにはせず、自分でフォントを指定した方が安定する。
dir属性
書字方向を示す[8]。
このwikiは日本語に対応しているので基本的に書字方向はltrとなっている。 そのため普通にアラビア文字などrtl属性の文字を書くと、ピリオドがラテン文字のものと共通しているためにそれだけ右側に行ってしまう。
- حَرَقَ تَاكَاهِيرُو كَارَاسَاوَا ٱلْقُرْآنَ وَأَهَانَ مُحَمَّدًا.
dir="rtl"
を設定すれば正しい表示がなされる。
- حَرَقَ تَاكَاهِيرُو كَارَاسَاوَا ٱلْقُرْآنَ وَأَهَانَ مُحَمَّدًا.
Unicodeで同様の動作をさせるには#双方向テキストを参照。この方法と組み合わせても良い。
縦書き
日本語の縦書きはCSSでwriting-mode: vertical-rl;
[9]を指定すれば良い。
英数字を縦にするにはtext-orientation: upright;
[10]を指定する。
2021年に唐澤貴洋knifeで
メッタ刺しにして殺す。
2021年に唐澤貴洋knifeで
メッタ刺しにして殺す。
モンゴル語や満洲語の場合はwriting-mode: vertical-lr;
を指定する。
Safariだと文字の向きが正しくなくなるので、text-orientation: sideways;
も指定する。
- ᠮᠤᠩᠭᠤᠯ
ᠬᠡᠯᠡ
回鶻語やソグド語の縦書きにはwriting-mode: sideways-lr;
を用いる。
但しFirefox以外のブラウザには対応していないので、writing-mode: vertical-rl;
をtransform: rotateZ(180deg);
で180度回転させる方が汎用性が高い。
- 𐽰𐽳𐽶𐽲𐽳𐽾
𐾀𐽶𐾁
右横書き
日本語でかつて用いられていた右横書きはCSSでdirection: rtl; unicode-bidi: bidi-override;
[11]で実現できる。
但し下のように多くの環境で約物が逆向きになる。
- 「唐澤貴洋殺す。」
日本語には元々右横書きが存在せず、一行一文字の縦書きであるという説もある。 [12]。
これをCSSで再現しようとするとwriting-mode: vertical-rl; height:1em;
となる。
約物の表示が縦書きのそれとなるので非常に不自然である。
- 「唐澤貴洋殺す。」
エジプト語で用いられるヒエログリフは、Unicode上では欧米の言語のスタイルに合わせてltrとなっているものの、古代エジプトの碑文にはrtlのものが圧倒的に多い[13]。
これを再現する場合、CSSでtransform: rotateY(180deg); display: inline-block;
を指定すれば良い。
- 𓂋𓏺𓈖𓆎𓅓𓏏𓊖
display: inline-block;
[14]を指定しているのはspanタグがインライン要素であるからであり、ブロックレベル要素に適用するならこれは不要。
次の例はブロックレベル要素であるpタグにtransform: rotateY(180deg);
のみ適用した例である。
右の方に寄っていてパッと見つけにくいので注意。
𓂋𓏺𓈖𓆎𓅓𓏏𓊖
ルビ
rubyタグ
HTMLのrubyタグで振り仮名を振ることができる[15]。
<ruby>唐澤貴洋<rt>からさわたかひろ</rt></ruby>
と記述することで下のような出力がなされる。
- 唐澤貴洋
更にrpタグを用いることで、rubyタグへの対応が無いブラウザでの表示をコントロールできる(でも今時そんなことをする必要はなさそう)。検索結果のスニペットにも現れる。
例えば<ruby lang="ko">唐澤貴洋<rp>(</rp><rt>당택귀양</rt><rp>)</rp></ruby>
の結果は下のようになる。
- 唐澤貴洋
但しrubyタグに対応していなければ下のようになる。
- 唐澤貴洋(당택귀양)
上の韓国語の例では、ハングルが詰まっているために漢字との対応が見づらくなっている。 これを解決するためにrbタグを用いるように解説しているサイトもあるが、標準ではなく推奨されておらず[16]、動作も安定しない。 面倒でも一文字ずつrtタグを振る必要がある。
次の例では、上の例文はrbタグを用いて<ruby lang="ko">唐<rb>澤<rb>貴<rb>洋<rp>(</rp><rt>당<rt>택<rt>귀<rt>양<rp>)</rp></ruby>
と、下の例ではrbタグを用いずに<ruby lang="ko">唐<rt>당</rt>澤<rt>택</rt>貴<rt>귀</rt>洋<rt>양</rt></ruby>
と記述している。
- 唐
澤 貴 洋 - 唐澤貴洋
ルビが長いと本文のスペースが大きくなる。
- 唐澤貴洋
縦書きではルビも縦書きになる。
次に示す例では、<span lang="min-TW" style="writing-mode: vertical-rl;"><ruby>唐澤貴洋<rp>(</rp><rt>トン𚿳チ̅ェㇰ𚿶クイ𚿱イウ𚿻</rt><rp>)</rp></ruby></span>
と記述している。
- 唐澤貴洋
rubyタグに直接writing-mode: vertical-rl;
を指定するとブラウザによってはルビの位置がおかしくなる。
次の例では<ruby style="writing-mode: vertical-rl;">唐澤貴洋<rp>(</rp><rt>𛀜𛃰𛀿𛂞𛁟𛀙𛂭𛄃</rt><rp>)</rp></ruby>
というように書いている。
- 唐澤貴洋
台湾で用いられている注音符号は横書きでも漢字の右側に振られる。
これを表示する為に、CSSのruby-positionにはinter-characterというものが定められている[17]が、これを実装しているブラウザは2021年9月7日現在ない。
次に示す例では、rubyタグにruby-position: inter-character;
を設定している。
- 唐澤貴洋
どうしても再現したいなら、一つの文字毎にrubyタグで囲み、spanタグにwriting-mode: vertical-rl;
というCSSを記述して縦書きにする。
文字が縦方向にガタつくことを防ぐため、spanタグにはCSSでvertical-align: middle;
を指定している。
下の例では、「唐」の字は<span style="writing-mode: vertical-rl; vertical-align: middle;"><ruby>唐<rt>ㄊㄤˊ</rt></ruby></span>
で記述されている。他の文字も全く同じようにしている。
先述の通り、rubyタグでCSSを指定せず、それを囲むspanタグを書いてそちらに指定する。
- 唐澤貴洋
ルビを2つ振るには、rubyタグ内でrtcタグ[18]を用いてルビをグループ化する。
但しこれも2021年9月7日現在Firefox以外では動作しない。
次の例では<ruby>唐澤貴洋<rp>(</rp><rt>たうたくきやう</rt><rp>)</rp><rtc><rp>(</rp><rt>だうぢやくきやう</rt><rp>)</rp></rtc></ruby>
と記述している。
- 唐澤貴洋
rubyタグを入れ子にすれば複数のルビを振ることができる。
下の例では<ruby lang="zh"><ruby style="ruby-position: under; -webkit-ruby-position: after;">唐泽贵洋<rp>(</rp><rt>Тон Зә Гуй Ён</rt><rp>)</rp></ruby><rp>(</rp><rt>táng zé guì yáng</rt><rp>)</rp></ruby>
と記述している。
- 唐泽贵洋
2つ目のrubyタグでruby-position: under;
を指定することで、ルビを文字の下に振っている。
しかしruby-positionは実験的なCSSであり、特にSafariに於いては2021年9月8日現在正式な実装がされていないため、ベンダープレフィックスを付けなければならない[19]。
また取ることのできる値もW3Cの定めたものとは異なる。ここでは-webkit-ruby-position: after;
と記述している。
このようになるべく多くのブラウザで挙動を同じくする為には、各ブラウザの対応を確認する必要がある[20]。
subタグ・supタグ
訓民正音が制定された直後の李氏朝鮮では、訛った漢語の読みを正そうという意識の下「東国正韻」が定められた。 その漢字音を広める為に漢字の下に小さい訓民正音で読みを書くという試みが一時期なされていた[21]が、当時博く用いられていた音とは異なっていたために受け入れられず、直ぐに廃れた[22]。
これをHTML上で表現するにはsubタグを用いれば良い。以下の例では、訓民正音の部分のみをすべてsubタグで囲んでいる。
- 世솅〮宗조ᇰ御ᅌᅥᆼ〮製졩〮訓훈〮民민正져ᇰ〮音ᅙᅳᆷ
但しこれを縦書きにすると読みの部分が左に寄ってしまう。
予영ㅣ爲〬윙〮此ᄎᆞᆼ〯憫민〯然ᅀᅧᆫᄒᆞ〮야〮
新신制졩〮二ᅀᅵᆼ〮十씹〮八바ᇙ〮字ᄍᆞᆼ〮ᄒᆞ〮노니〮
欲욕〮使ᄉᆞᆼ〯人ᅀᅵᆫ人ᅀᅵᆫᄋᆞ〮로〮易〬잉〮習씹〮ᄒᆞ〮야〮
便뼌於ᅙᅥᆼ日ᅀᅵᇙ〮用요ᇰ〮耳ᅀᅵᆼ〯니라〮
これを防ぐには、subタグの代わりにsupタグを用いれば良い。
나랏〮말〯ᄊᆞ미〮
中듀ᇰ國귁〮에〮달아〮
文문字ᄍᆞᆼ〮와〮로〮서르ᄉᆞᄆᆞᆺ디〮아니〮ᄒᆞᆯᄊᆡ〮
이〮런젼ᄎᆞ〮로〮어린〮百ᄇᆡᆨ姓셔ᇰ〮이〮니르고〮져〮호ᇙ〮배〮이셔〮도〮
ᄆᆞᄎᆞᆷ〮내〯제ᄠᅳ〮들〮시러〮펴디〮몯〯ᄒᆞᇙ노〮미〮하니〮라〮
これらのタグを用いて漢文の返り点や口訣などを表記することができる。
但し返り点と送り仮名は[23]や[24]に従い、位置を調整するために 
(和字間隔)を多用している。
無㆓ 恆產㆒而有󠄁㆓恆心㆒者󠄁、惟士 爲㆑能。
若㆑民則無㆓ 恆產、㆒ 因 無㆓恆心。㆒
將㆑殺󠄀㆓ 唐󠄁澤貴洋。㆒
無恒産而有恒心者󠄁惟士爲能
若民則無恒産因無恒心
無恒産而有恒心者󠄁는 惟士爲能이어
니와
若民則無恒産이면 因無恒心이니
라
文字参照
HTMLのマークアップに使われる文字や互換漢字などは、その文字そのものを書いても別の形に変換されてしまう。 これを防ぐには文字参照を用いて別の形で記述する。
例えば<や>はHTMLのマークアップには欠かせない文字である。 下記の説明ではHTMLのマークアップ自体を見える形で表示しているが、当然ただHTMLを書くだけではマークアップは変換されてレンダリングされてしまう。
- 記述上
<div style="border: solid 3px #000000;">
<p>東京高等裁判所平成27年(ネ)第1347号</p>
<p>・依頼者はステロイドを過剰に処方され色素沈着&パニック障害発症</p>
<p>・病院を相手取った控訴審になぜかパカデブを起用(医療に強い唐澤貴夫弁護士と混同した可能性大)</p>
<p>・パカデブ、医療訴訟の経験もないのに引き受ける</p>
<p>・案の定爆死。医療ミスの事実すら完全に否定され控訴棄却という最悪の結果に</p>
<p>・依頼者は病院の責任も追及できず30万ぼったくられて泣き寝入り</p>
</div>
- 実際の表示
東京高等裁判所平成27年(ネ)第1347号
・依頼者はステロイドを過剰に処方され色素沈着&パニック障害発症
・病院を相手取った控訴審になぜかパカデブを起用(医療に強い唐澤貴夫弁護士と混同した可能性大)
・パカデブ、医療訴訟の経験もないのに引き受ける
・案の定爆死。医療ミスの事実すら完全に否定され控訴棄却という最悪の結果に
・依頼者は病院の責任も追及できず30万ぼったくられて泣き寝入り
「記述上」に示したように表示するには、<の代わりに<
と、>の代わりに>
と記述している。
- 編集画面でのHTMLソースの記述
<div style="border: solid 3px #000000;">
<p>東京高等裁判所平成27年(ネ)第1347号</p>
<p>・依頼者はステロイドを過剰に処方され色素沈着&パニック障害発症</p>
<p>・病院を相手取った控訴審になぜかパカデブを起用(医療に強い唐澤貴夫弁護士と混同した可能性大)</p>
<p>・パカデブ、医療訴訟の経験もないのに引き受ける</p>
<p>・案の定爆死。医療ミスの事実すら完全に否定され控訴棄却という最悪の結果に</p>
<p>・依頼者は病院の責任も追及できず30万ぼったくられて泣き寝入り</p>
</div>
<と表示したいなら&lt;
と記述すれば良い。
或いは<nowiki>
を用いる方法もある。
文字参照には文字実体参照と数値文字参照とが存在する。
文字実体参照は上記に示したように<
のような形で文字を表すものである。
一部の文字にのみ定められている。
数値文字参照はISO/IEC 10646に定められた数字(Unicodeのものと同一)を参照して表示するものである。
例えば<(U+003C)を表示するなら、<
と記述すれば良い。
これを用いればCJK互換漢字のように正規化されてしまう文字もそのまま表示できる。
但し異体字を表示する目的で用いるなら、互換漢字を用いずにIVS異体字を用いるべきである。
Webフォント
注: この方法は外部のフォントファイルをダウンロードするので、自サイトに置いたWebフォントファイルを用いるよりも動作が遅くなる可能性がある。MediaWiki:Common.cssでは濫用せず、利用者:Fet-Fe/common.cssなどの利用者毎のcommon.cssで用いるようにすること。
- Google Fontsから使いたいフォントを探す
- 使いたいフォントをクリックし、使いたいスタイルを選んで"Select this style"をクリック
- 必要な分だけ選んだら、画面右上のボタンをクリックすると選んだfont familiesを見ることができる。@importをクリックし、
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Infant&display=swap');
のような文字列をコピーする - CSSファイルにコピーしたテキストを貼り付け、保存する
- あとは
<span style="font-family: 'Cormorant Infant';">Убʼю Карасаву Такахіро.</span>
のようにフォントを選択したり、CSSファイル側で設定したりできる
気になる資料
- Pablo Sánchez Domínguez, Origen y gramática del romance andalusí, Córdoba: Editorial Almuzara, 2020.
Fr. Francis T.J. Sdb, First Ever Wancho Grammar cum English-Wancho Tutor, Dimapur: Don Bosco Publications, 2007.Gholam Djelani Davary, Baktrisch : ein Wörterbuch, Heidelberg: Julius Groos, 1982.- Alfred Schmitt, Die Bamum-Schrift, Wiesbaden: Otto Harrassowitz, 1963.
どっかにPDFでも落ちてないナリかねえ
脚註
- ↑ https://www.unicode.org/charts/PDF/U2FF0.pdf
- ↑ https://www.unicode.org/charts/PDF/UE0100.pdf
- ↑ http://www.unicode.org/charts/PDF/U0000.pdf
- ↑ https://www.unicode.org/charts/PDF/U2000.pdf
- ↑ https://www.unicode.org/charts/PDF/U02B0.pdf
- ↑ Format Characters Suitable for Use with Markup - W3C Working Group Note
- ↑ https://developer.mozilla.org/ja/docs/Web/HTML/Global_attributes/lang
- ↑ https://developer.mozilla.org/ja/docs/Web/HTML/Global_attributes/dir
- ↑ https://developer.mozilla.org/ja/docs/Web/CSS/writing-mode
- ↑ https://developer.mozilla.org/ja/docs/Web/CSS/text-orientation
- ↑ https://developer.mozilla.org/ja/docs/Web/CSS/direction
- ↑ 戦前の左横書き - みんなのかなづかひ(魚拓)
- ↑ 永井正勝 (2005) 古代エジプト聖刻文字の書字方向: 一般統字論構築の一助として. 『一般言語学論叢』8: 21–45. 筑波一般言語学研究会.
- ↑ https://developer.mozilla.org/ja/docs/Web/CSS/display
- ↑ https://developer.mozilla.org/ja/docs/Web/HTML/Element/ruby
- ↑ https://developer.mozilla.org/ja/docs/Web/HTML/Element/rb
- ↑ https://developer.mozilla.org/ja/docs/Web/CSS/ruby-position
- ↑ https://developer.mozilla.org/ja/docs/Web/HTML/Element/rtc
- ↑ https://developer.mozilla.org/ja/docs/Web/CSS/ruby-position#browser_compatibility
- ↑ 但しIEのレンダリングが死んでもなんとも思わん
- ↑ 福井玲 (2015) 中世韓国語の「傍点」をめぐるいくつかの基本的な課題. 『言語研究』148: 61–80. 日本言語学会.
- ↑ 中期朝鮮語の話 - 趙義成の朝鮮語研究室(魚拓)
- ↑ 漢文の句読点や返り点の配置処理 - 公益社団法人日本印刷技術協会
- ↑ 漢文の送り仮名・読み仮名の配置処理 - 公益社団法人日本印刷技術協会