Youtubeでも活動中

チャンネル登録してくれたら喜びます。

このボタンで簡単にチャンネル登録!

RaspberryPiでWindows10PCのMySQLテーブルに【Python】でアクセス

MySQL

今回の記事は、

windows10PCにあらかじめ作成しておいたデータベースに

RaspberryPiからアクセスしてみよう。

というお話です。

もちろん無線LANを経由していますので、

配線は不要です。

作業の説明が長いですが、

実際の作業は実は簡単です。

ぜひマスターしてみてください。一気に幅が広がりますよ!!

本題の前に軽く自己紹介します。

自己紹介

東証一部上場企業でサラリーマンしてます。

主に工場(生産現場)で使用する検査装置のアプリケーション開発してます。

ヒトの作業を自動化して簡略化するアプリケーションを日々開発中。

転職に成功して現在は超大手企業でシステム系の開発をしています。

Youtubeチャンネルにさまざまな動画を上げています

↓↓↓こちらからYoutubeチャンネルにアクセス!! ↓↓↓

それではこの記事の内容について見ていきましょう。

この記事を読んでできるようになること。

この記事を読んでできるようになること
  • RaspberryPiでMySQLを使えるようになる。
  • RaspberryPiでOSの違うPCのデータベースにアクセスできるようにある。
  • RaspberryPiを使って無線通信でデータベースにアクセスできるようになる。

どんな時にこのシステムが使えるか。

例えば、こんな時にこのシステムを使うとメリットがあります。

このシステムを使うのにメリットがあるシチュエーション
  • RaspberryPi楽しいけど、データをメインPCに飛ばしたい。
  • Windows用のセンサーは無いけど、RaspberryPiで扱えるセンサーはある。
  • とにかくいろんなデータを安い設備費用で集めたい。

RaspberryPi楽しいけど、データをメインPCに飛ばしたい。

RaspberryPiは電子工作が楽しいコンピュータですが、

おそらく日常のメインPCとして使用している人は少ないでしょう。

そんな中、RaspberryPiで取得したセンサーのデータなど、

メインPCでまとめたいな。

なんてこともあると思います。それも、

RaspberryPiから自動的にできたら

とても便利ですよね。

それに今回ご紹介するのは無線通信ですので、

LANケーブルが邪魔になることもありません。

マスターできれば、電子工作の幅が広がること間違いなしですね!

Windows用のセンサーは無いけど、RaspberryPiで扱えるセンサーはある。

よくある話ですが、RaspberryPi用のセンサーを大量に持っていて、

ちょっとメインのWindowsPCでもRaspberryPi用のセンサー使いたい。

っていうシチュエーションてあると思います。

また、センサー類がドライバーが必要なUSB接続式のWindows用だと

ちょっと高額になりますよね。

もちろんパッケージングされている分手間がかかっているので、

値段設定がおかしいということではないんですが…

センサーの代表選手温度計を例に挙げると…

こちらのシンプルなUSB温度計でさえこの値段ですが、

こちらの、みんな大好きDHT11のパチモンはなんと

同じ値段で5個買えてしまいます。

まあ、まず個人で5個も買ってどうするんだ

って話はあるんですが笑

同じ値段で5個買えてしまいます。

とにかくいろんなデータを安い設備費用で集めたい。

↑のお話でセンサーがUSB用よりも

だいぶ割安というお話をしましたが、

Point

RaspberryPi本体がそもそも1万円で購入できるので、

いろいろな場所に設置してデータが取りたい場合に、

大きなメリットとなります。

本当にコストを抑えるなら、Arduinoが最強なんですが、

それは本題からそれるので、

今回は割愛します。

MySQLの接続イメージ

絵にするほどのことでもないのですが、

今回接続するイメージ図を用意しました。

windowsとRaspberryPiの接続のイメージ図

とにかく、LinuxベースのRaspberryPiから

Windows10PCにアクセスするよ。

ってことが言いたいです笑

準備する物

それでは実際必要なものをご紹介していきます。

どこの家庭にもあるような物ばかりですので、

すでにお持ちの方がほとんどだと思います。

Wi-Fiルーターの調子が悪い方はこの際思い切って

新しいスタートということで、

買い替えなんていいんじゃないでしょうか。

MySQLのインストールされたWindows10PC

はい、こちらはデスクトップでもノートでも構いません。

まだWindowsにMySQLをインストールしていない。

という方はこちらでインストール方法を紹介していますので、

参考にしてみてください。

変わり種としてタブレットでも、まあ行けると思います。

ちょっと試していないので何ともですが、

Windowsタブレットって確かタブレット用のOSになっていないはずなので、

多分行けるはずです。

VSCODEのインストールされたRaspberryPi

RaspberryPiですね。

何はともあれこれがないと始まりません。

VSCODEが入っている、としたのは

完全に私の趣味です笑

お気に入りのエディタがある方は

無理してインストールする必要はありません。

無線LAN親機

以外と大事なこちらですね。

私は最近TP-Linkの安物を買って後悔しているんですが、

オススメできるのはやはりBuffalo製のWi-Fiルータですね。

例えばこんなWi-Fiルータでしょうか。

接続の手順その1(Windows10PC側)

今回無線で接続しますが、いくつかポイントがあります。

やることの中身はRaspberryPiと同じなのですが、

具体的な手順が異なるので注意してください。

順番Windows10PCで行う手順
今接続しているWindowsPCのIPアドレスを調べる
Wi-FiルータのIPアドレス(デフォルトゲートウェイ)を調べる
IPアドレスを決めて固定する
接続されるまで待つ

パソコン類の、ネットワークに繋ぐ機器は

すべてIPアドレスなんて手動の固定だ!!

というガチな方は飛ばしていただいて大丈夫です。

何を言ってるかわからない人は、

素直に読み進めていってください!!

今接続しているWindowsPCのIPアドレスを調べる

まずは今お使いのWindowsPCをネットにつなげてください。

もちろん無線でお願いします。※一応有線でも大丈夫です。

Wi-Fiルータと無線でも有線でもつながっているのが重要です。

windows10PCのIPアドレスの調べ方

それでは前置きが長くなりましたが、IPアドレスの調べ方です。

まずはコマンドプロンプトを開いてください。

コマンドプロンプトの検索結果

キーボードのWindowsキーを押して、

cmdと打つとおそらく一番上に表示されます。

起動したら、

ipconfig

と打ち込んでEnterキーを押して下さい。

するとよくわからない内容が、

ズラッと出てくるはずです。

メモするところは↓の黄色の線で囲んだところです。

windowsPC側の現在のIPアドレス周りをメモしましょう。

忘れないようにどこかにメモしておきましょう。

もちろんPCのメモ帳でも大丈夫です。

Wi-FiルータのIPアドレス(デフォルトゲートウェイ)を調べる

Wi-FIルータのIPアドレスですが、

重要なのが、ルーターにもIPアドレスが指定されていて、

こいつをしっかりとPC側にも指定してあげないと、

PCやRaspberryPiで固定IPアドレスで接続したときに

挙動がおかしくなります。

Wi-FiルータのIPアドレスの調べ方

実はこちら、先ほどメモしていた

デフォルトゲートウェイという物です。

ですから、改めて何かする必要はありません。

IPアドレスを決めて固定する

先ほどメモしたIPv4アドレスなどを使用して、

具体的に通信できるように設定していきます。

手順通りにやれば難しくありません。

それではやっていきましょう。

まずはWindowsのスタートボタンを押して出てくる、

歯車のマークのアイコンを押して、

↓のような画面にしてください。

ネットワークとインターネットを選ぶ

ネットワークとインターネットを選択。

設定内の、ネットワークとインターネットを選択しましょう。

ネットワーク関係の設定はこちらからできますので、

覚えておきましょう。

アダプターのオプションを変更する

まず左のタブから、

状態タブを選択してください。

その後、オレンジでマーキングした

アダプターのオプションを変更する を左クリックしてください。

アダプターのオプションを変更する。

IPv4プロパティを表示させる

IPv4の設定方法手順。

↑のように、①~④まで順番にクリックしていきましょう。

説明としては、

①で今現在無線で接続されているWi-Fiルータを選択。

②でルータとの接続のプロパティを表示させる。

③でIPv6を使用しないように設定変更。

この設定については、

今回IPv4で決め打ちで接続(※そのほうが簡単)したいので、

IPv6は使用しないように、

チェックボックスは外しています。

④はIPv4の設定を開くためにダブルクリックします。

IPアドレス、デフォルトゲートウェイなどを固定する

IPv4のプロパティは出てきましたか??

windowsPC(サーバ側)とルーターのIPアドレスを設定。

出てきたら↑のように、①~③まで順番に操作していきましょう。

説明ですが、まずはメモしたIPアドレスなどが必要になりますので

手元に用意してから操作を始めましょう。

説明としては、

①はIPアドレスを自動取得から、固定にします。

②は、メモしておいたアドレスを打ち込みます。

サブネットマスクですが、

255.255.255.0

で特に問題ないです。

デフォルトゲートウェイもメモしているはずですので、

そちらを書いてください。

③はDNSサーバーとありますが、

デフォルトゲートウェイと同じものを入れてください。

接続されるまで待つ

ここまでくれば、

windowsのほうの設定は終わりになります。

インターネットにつながるか?

また、再度コマンドプロンプトで

ipconfig

と打ち込んで打ち込んだIPv4アドレスになっていれば、

特に問題ありません。

接続の手順その2(Raspberry側)

それではWindows側の設定が終わりましたので、

次はRaspberryPi側の設定に移りましょう。

設定する内容はWindowsと一緒です。

順番RaspberryPiで行う手順
今接続しているRaspberryPiのIPアドレスを調べる
IPアドレスを決めて固定する
接続されるまで待つ

それではさっそく↑の表のとおり説明していきます。

RaspberryPiのIPアドレスを調べる

Windowsではコマンドプロンプトから

調べていましたが、

RaspberryPiは、LXターミナル、

いわゆるRaspberryPi版のコマンドプロンプトから

調べることができます。

コマンドはWindowsとは異なりますが、

ifconfig

と打ち込んでみましょう。

するとずらっと表示されるのですが、

RaspberrPiの現在のIPアドレスは、

raspberrypiのLXターミナルでifconfigと打った結果画面。

broadcastというところに表示されています。

そのアドレスをまたメモしておきましょう。

これが現在のラズパイのIPアドレスです。

windowsと同様、後ほど使用します。

RaspberryPiのIPアドレスを固定する

それでは、先ほどメモしたIPアドレスに

RaspberryPiを固定していきましょう。

操作としては、まず画面のWi-Fiマークを

右クリックしてください。

するとこちらのようにタブが表示されますので、

一番上のWireless&~~~Setting

ラズパイのネットワーク設定を開く。

というのを選択して下さい。

すると今度はこのような画面が出てくるはずです。

ラズパイのIPアドレスとルーターのIPアドレスを固定する。

設定することの説明ですが、

①ではwlan0を選択してください。

②ではWindowsの時と同様にIPv6を使用しないので、

チェックボックスにチェックを入れてください。

③では、先ほどメモしたbroadcastの値を入れてください。

④ではルーターのIPアドレスを入れてください。

接続されるまで待つ

ここまででRaspberryPiの設定は完了なのですが、

重要なこととしては、RaspberryPiは、

再起動(reboot)しないとここまでやってきたIPアドレスの設定が反映されません。

Windowsの時はすぐに反映されますが、

RaspberryPiはそうはならないので、

設定が完了したら、適用ボタンを押して

RaspberryPiを再起動しましょう。

接続の手順その3(ソフト側)

ここまででハード側の設定は完了しました。

あとはRaspberryPiでWindows側にアクセスするだけです。

ただし、windows側のMySQLにアクセスする場合、

ログイン用のUserを作成しておいたほうが良いです。

Userの作成はアクセスされるWindows側で行いますが、

記事が長くなってしまうので、別記事で紹介いたします。

RaspberryPiのPythonの準備

RaspberryPiには初めからPythonがインストールされていますが、

エディターがちょっと使いづらいので、

VSCODEをオススメしています。

関連記事はこちら↓↓↓

VSCODEとは

pythonでMySQLを操作する方法ですが、

すでにWindowsのみで完結させる方法は記事にしているのですが、

※そのときの記事はこちら↓↓↓

PythonでMySQLやってみる

実はRaspberryPiでは同じモジュールが使えません。

そのため、PyMySQLというモジュールを使用します。

pipでPyMySQLをインストールしてください。

具体的には、

VSCODEのターミナルで、

pip install PyMySQL

と打ち込んで実行してください。

Pythonのソースコード

それではRaspberryPiでMySQLを

操作するモジュールもインストールできたので

実際に操作してみましょう。

こちらが実際のソースコードです。

# PythonでMySQLを使用するために必要なライブラリ
import pymysql.cursors
# データベースにアクセスするためのパラメータ 
connection = pymysql.connect(host='Windows側のIPアドレス',
    user='アクセス用のユーザー名',
    password='アクセス用のパスワード',
    db='world',
    charset='utf8',
    # Selectの結果をdictionary形式で受け取る
    cursorclass=pymysql.cursors.DictCursor)
# カーソルを取得する
cur = connection.cursor()
# プリインストールされているデータベース(worldを選択)
sql = "use world"
cur.execute(sql)
# worldに格納されているテーブル(city)のカラム属性を取得する
sql="select* from city where Name='Tokyo'"
cur.execute(sql)
# 実行結果を取得する
rows = cur.fetchall()
# 一行ずつ表示する
for row in rows:
 print(row)
cur.close
connection.close

ユーザー名やパスワード、ホストは

皆さん環境によって違うので、

それぞれご自分の環境に合わせて変更してください。

Tokyoの情報が出てきたら成功です!

ちなみに….

テストしてexcuteできない場合(エラーになる場合)は、

今一度LXターミナルを開き、

ping windowsPCの固定したIPアドレス

と打って、そもそもつながっているか確認しましょう。

具体例として、もしwindowsPCのIPv4アドレスを、

192.168.1.1としていた場合は、

ping 192.168.1.1

このように打ち込んでEnterを押しましょう。

unreachableと出てきたらそれは接続できていないということです。

もしraspberryPiからpingが通っていなかったら。

つい最近あったトラブルですが、

windowsPC側のIPアドレスも、wifiルーターのIPアドレスも、ラズパイのIPアドレスも固定し、

mysqlをつなごうとしても、「一向につながる気配がない…」

むしろ、先ほどのpingでwindowsPCへのアクセスを試みても、

うんともすんともいわない問題が発生しました。

解決方法。

こちらの記事が参考になりました。

【ラズパイ】WiFiのIPを固定にしたらネットに繋がらなくなった場合の解決方法 | 夢幻電脳館
ラズパイのWiFi接続で固定IPにしてみたらネットがうまく繋がらなくなってしまいました。 なんだかんだでハマってしまいましたが、何とか解決に至りましたので参考になる方がいればと思い記録として公開してお...

特に参考になったというか、

ここで解決したよ。というのが、

dhcpcd.conf

ラズパイのこのconfigが悪さをしていました。

手順は参考記事の通りですが、一応念のため紹介しておきますが、

dhcpcd.confの位置は、

LXターミナルを開いたディレクトリから、etcに移動した中に存在します。

というわけでそもそものdhcpcd.confの開き方ですが、

cd /etc
open dhcpcd.conf

上記の命令を一行ずつLXターミナルで打ってEnterしてください。

すると、テキストエディタでdhcpcd.confが開きます。

その中の、

inform [IPアドレス]

となっているところ(下のほう)を、

static ip_adress=ipアドレス

とすることによって解決しました(私の場合)。

例えばラズパイのIPアドレスを

192.168.1.50で固定したはずなのにつながらない場合、

inform 192.168.1.50

となっているところがないか、dhcpcd.confで探します。

もし、そうなっているところを見つけたら、

static ip_adress=192.168.1.50

このように変更して保存しましょう。

保存後は再起動しましょうね。(reboot)



独学の限界を感じているあなた。

昨今のトレンドに乗り遅れていませんか?

「苦労して少ない情報をネット検索するのはもうやめましょう。」

プログラミング習得のテッパンはずばりスクールです。

「無料でpythonの基礎」を習得しませんか?

すでに1万人以上が受講している人気講座です。

時代のトレンドに乗り遅れる前に今のうちに習得しておきませんか??

コメント

'}},vars:{discoveredBrushes:null,highlighters:{}},brushes:{},regexLib:{multiLineCComments:XRegExp("/\\*.*?\\*/","gs"),singleLineCComments:/\/\/.*$/gm,singleLinePerlComments:/#.*$/gm,doubleQuotedString:/"([^\\"\n]|\\.)*"/g,singleQuotedString:/'([^\\'\n]|\\.)*'/g,multiLineDoubleQuotedString:XRegExp('"([^\\\\"]|\\\\.)*"',"gs"),multiLineSingleQuotedString:XRegExp("'([^\\\\']|\\\\.)*'","gs"),xmlComments:XRegExp("(<|<)!--.*?--(>|>)","gs"),url:/https?:\/\/[\w-.\/?%&=:@;#]*/g,phpScriptTags:{left:/(<|<)\?(?:=|php)?/g,right:/\?(>|>)/g,eof:!0},aspScriptTags:{left:/(<|<)%=?/g,right:/%(>|>)/g},scriptScriptTags:{left:/(<|<)\s*script.*?(>|>)/gi,right:/(<|<)\/\s*script\s*(>|>)/gi}},toolbar:{getHtml:function(e){function t(e,t){return B.toolbar.getButtonHtml(e,t,B.config.strings[t])}for(var n='
',r=B.toolbar.items,i=r.list,a=0,l=i.length;l>a;a++)n+=(r[i[a]].getHtml||t)(e,i[a]);return n+=""},getButtonHtml:function(t,n,r){return n=e(n),''+e(r)+""},handler:function(e){function t(e){var t=RegExp(e+"_(\\w+)"),n=t.exec(r);return n?n[1]:null}var n=e.target,r=n.className||"",i=s(g(n,".syntaxhighlighter").id),a=t("command");i&&a&&B.toolbar.items[a].execute(i),e.preventDefault()},items:{list:["expandSource","help"],expandSource:{getHtml:function(e){if(1!=e.getParam("collapse"))return"";var t=e.getParam("title");return B.toolbar.getButtonHtml(e,"expandSource",t?t:B.config.strings.expandSource)},execute:function(e){var t=o(e.id);r(t,"collapsed")}},help:{execute:function(){var e=x("","_blank",500,250,"scrollbars=0"),t=e.document;t.write(B.config.strings.aboutDialog),t.close(),e.focus()}}}},findElements:function(e,t){var n=t?[t]:i(document.getElementsByTagName(B.config.tagName)),r=B.config,a=[];if(r.useScriptTags&&(n=n.concat(A())),0===n.length)return a;for(var l=0,s=n.length;s>l;l++){var o={target:n[l],params:p(e,E(n[l].className))};null!=o.params.brush&&a.push(o)}return a},highlight:function(e,t){var n=this.findElements(e,t),r="innerHTML",i=null,a=B.config;if(0!==n.length)for(var l=0,s=n.length;s>l;l++){var o,t=n[l],u=t.target,c=t.params,g=c.brush;if(null!=g){if("true"==c["html-script"]||1==B.defaults["html-script"])i=new B.HtmlScript(g),g="htmlscript";else{var h=b(g);if(!h)continue;i=new h}o=u[r],a.useScriptTags&&(o=M(o)),""!=(u.title||"")&&(c.title=u.title),c.brush=g,i.init(c),t=i.getDiv(o),""!=(u.id||"")&&(t.id=u.id),u.parentNode.replaceChild(t,u)}}},all:function(e){m(window,"load",function(){B.highlight(e)})}};return B.Match=function(e,t,n){this.value=e,this.index=t,this.length=e.length,this.css=n,this.brushName=null},B.Match.prototype.toString=function(){return this.value},B.HtmlScript=function(e){function t(e,t){for(var n=0,r=e.length;r>n;n++)e[n].index+=t}function n(e){for(var n,a=e.code,l=[],s=r.regexList,o=e.index+e.left.length,u=r.htmlScript,c=0,g=s.length;g>c;c++)n=L(a,s[c]),t(n,o),l=l.concat(n);null!=u.left&&null!=e.left&&(n=L(e.left,u.left),t(n,e.index),l=l.concat(n)),null!=u.right&&null!=e.right&&(n=L(e.right,u.right),t(n,e.index+e[0].lastIndexOf(e.right)),l=l.concat(n));for(var h=0,g=l.length;g>h;h++)l[h].brushName=i.brushName;return l}var r,i=b(e),a=new B.brushes.Xml,l=this,s="getDiv getHtml init".split(" ");if(null!=i){r=new i;for(var o=0,u=s.length;u>o;o++)(function(){var e=s[o];l[e]=function(){return a[e].apply(a,arguments)}})();return null==r.htmlScript?(v(B.config.strings.brushNotHtmlScript+e),void 0):(a.regexList.push({regex:r.htmlScript.code,func:n}),void 0)}},B.Highlighter=function(){},B.Highlighter.prototype={getParam:function(e,t){var n=this.params[e];return d(null==n?t:n)},create:function(e){return document.createElement(e)},findMatches:function(e,t){var n=[];if(null!=e)for(var r=0,i=e.length;i>r;r++)"object"==typeof e[r]&&(n=n.concat(L(t,e[r])));return this.removeNestedMatches(n.sort(k))},removeNestedMatches:function(e){for(var t=0,n=e.length;n>t;t++)if(null!==e[t])for(var r=e[t],i=r.index+r.length,a=t+1,n=e.length;n>a&&null!==e[t];a++){var l=e[a];if(null!==l){if(l.index>i)break;l.index==r.index&&l.length>r.length?e[t]=null:l.index>=r.index&&i>l.index&&(e[a]=null)}}return e},figureOutLineNumbers:function(e){var t=[],n=parseInt(this.getParam("first-line"));return y(e,function(e,r){t.push(r+n)}),t},isLineHighlighted:function(e){var t=this.getParam("highlight",[]);return"object"!=typeof t&&null==t.push&&(t=[t]),-1!=h(t,""+e)},getLineHtml:function(e,t,n){var r=["line","number"+t,"index"+e,"alt"+(""+(0==t%2?1:2))];return this.isLineHighlighted(t)&&r.push("highlighted"),0==t&&r.push("break"),'
'+n+""},getLineNumbersHtml:function(e,t){var n="",r=a(e).length,i=parseInt(this.getParam("first-line")),l=this.getParam("pad-line-numbers");1==l?l=(""+(i+r-1)).length:1==isNaN(l)&&(l=0);for(var s=0;r>s;s++){var o=t?t[s]:i+s,e=0==o?B.config.space:S(o,l);n+=this.getLineHtml(s,o,e)}return n},getCodeLinesHtml:function(e,t){e=C(e);for(var n=a(e),r=(this.getParam("pad-line-numbers"),parseInt(this.getParam("first-line"))),e="",i=this.getParam("brush"),l=0,s=n.length;s>l;l++){var o=n[l],u=/^( |\s)+/.exec(o),c=null,g=t?t[l]:r+l;null!=u&&(c=""+u[0],o=o.substr(c.length),c=c.replace(" ",B.config.space)),o=C(o),0==o.length&&(o=B.config.space),e+=this.getLineHtml(l,g,(null!=c?''+c+"":"")+o)}return e},getTitleHtml:function(t){return t?""+e(t)+"":""},getMatchesHtml:function(e,t){function n(e){var t=e?e.brushName||a:a;return t?t+" ":""}for(var r=0,i="",a=this.getParam("brush",""),l=0,s=t.length;s>l;l++){var o,u=t[l];null!==u&&0!==u.length&&(o=n(u),i+=N(e.substr(r,u.index-r),o+"plain")+N(u.value,o+u.css),r=u.index+u.length+(u.offset||0))}return i+=N(e.substr(r),n()+"plain")},getHtml:function(t){var n,r,i,a="",s=["syntaxhighlighter"];return 1==this.getParam("light")&&(this.params.toolbar=this.params.gutter=!1),className="syntaxhighlighter",1==this.getParam("collapse")&&s.push("collapsed"),0==(gutter=this.getParam("gutter"))&&s.push("nogutter"),s.push(this.getParam("class-name")),s.push(this.getParam("brush")),t=w(t).replace(/\r/g," "),n=this.getParam("tab-size"),t=1==this.getParam("smart-tabs")?R(t,n):H(t,n),this.getParam("unindent")&&(t=P(t)),gutter&&(i=this.figureOutLineNumbers(t)),r=this.findMatches(this.regexList,t),a=this.getMatchesHtml(t,r),a=this.getCodeLinesHtml(a,i),this.getParam("auto-links")&&(a=I(a)),"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.match(/MSIE/)&&s.push("ie"),a='
'+(this.getParam("toolbar")?B.toolbar.getHtml(this):"")+''+this.getTitleHtml(this.getParam("title"))+""+""+(gutter?'
'+this.getLineNumbersHtml(t)+"":"")+''+'
'+a+""+""+""+""+""+""},getDiv:function(e){null===e&&(e=""),this.code=e;var t=this.create("div");return t.innerHTML=this.getHtml(e),this.getParam("toolbar")&&m(c(t,".toolbar"),"click",B.toolbar.handler),this.getParam("quick-code")&&m(c(t,".code"),"dblclick",X),t},init:function(e){this.id=f(),u(this),this.params=p(B.defaults,e||{}),1==this.getParam("light")&&(this.params.toolbar=this.params.gutter=!1)},getKeywords:function(e){return e=e.replace(/^\s+|\s+$/g,"").replace(/\s+/g,"|"),"\\b(?:"+e+")\\b"},forHtmlScript:function(e){var t={end:e.right.source};e.eof&&(t.end="(?:(?:"+t.end+")|$)"),this.htmlScript={left:{regex:e.left,css:"script"},right:{regex:e.right,css:"script"},code:XRegExp("(?"+e.left.source+")"+"(?.*?)"+"(?"+t.end+")","sgi")}}},B}();"undefined"!=typeof exports?exports.SyntaxHighlighter=SyntaxHighlighter:null;
タイトルとURLをコピーしました