投稿

キーボード修理

イメージ
前回 調子が悪くなったと書きましたが、部品が手配できて時間が取れたので直しました。 茶軸のスイッチを購入 Cherryの茶軸は 10個で1,399- ということで購入。 本当は1個で充分なんだけど、仕方なく残りは予備部品として保管。 作業手順 キーボードの裏側ネジを3箇所外します。 左右と中央の丸シールの下。 左右はパッドを貼っているので、少しめくって外します。 (あとで綺麗に戻るので心配なしです) ケーブルが出ている方は、スッと外れ、手前(下側)は、内部に爪が有るので、ピックやカード、マイナスドライバなどで少し隙間を開けるようにして広げれば外れます。 自分は親指の爪で空きました。 今回は「E」が調子悪いので、該当のピン2箇所をハンダ吸いで綺麗に取り除いて、裏側から引き抜いて完了。 基板にしっかりとどのキーかがプリントされているので分かりやすいですねぇ 入手した新品の茶軸を差し込んでハンダ付けします。 この時点で動作確認が可能になるので、直したキーとその周辺が正しく入力できるのをチェック。 問題なく、無事に動作しました。 最後にカバーを取り付けて完了! 残ったのは9個の茶軸…。 今回の費用 Cherryの茶軸10個セット :1,399- キーキャップ引き抜き工具 : 475-  ちなみに10個セットには、簡易引き抜きがついてきますが、ちゃんとしたもののほうが楽に作業できます。(昔買ったのに、どこかに行ってしまったので再購入)  ということで、1900円ほどで完治しました。  手間賃考えると買ったほうが安いかも(笑)

YOSEMITEの日本語入力

イメージ
MarvericksからUpgradeして Upgradeして、Googleの日本語入力を辞めてみたものの、相違点に戸惑っているが、ドキュメントが少なすぎる点が、問題な気がする。 利用しながら見つけた機能をまとめておこうと思う。 日本語入力する時に、便利なショートカットキーがいくつかあった。 入力中変換時に次のキーを押す option+A・・・半角アルファベット option+S・・・半角カタカナ option+X・・・全角カタカナ option+C・・・全角アルファベット に固定変換してくれる。 これで、ほんの少しだけれど、入力にイラつくことはない。 ただ、キーボードビューワーの表示と動作が異なるのは、なんでだろう?? 本来であれば順に「åß≈ç」なんだけど、これは未確定文字のない時にしか入力できない。 もう一つ、キーボードビューワーのオレンジ表示が何を意味するのか、まったく不明。 別に普通に入力できるし、未確定文字があっても動作に変化はない・・・。 キーボードビューワーとの相違点 他にも、ビューワーで表示されているものと、実際に入力される文字が異なっている点が不思議。 option+:・・・「‥」本来であれば「ae」が入るはずなのに。 他の記号もほとんど異なっている。 」「、。・ →  ][,./ やっぱり気持ち悪い。 日本語入力については、フォーラムでいろいろと書かれているので、心配な人はそちらも参考にすると良いですね。 Yosemite 日本語入力 勝手にローマ字に変換  「か」の変換の際の不具合 今回のYosemiteの搭載の日本語IMを外したいのですが など、ちょろっと見ただけでも結構な量です。 念のため 慣れれば問題ないのかもしれないけれど、別のツールも用意しておこうと思う。 有名どころの「Karabiner」を入れておく。 気になったら、すぐに変更できるようにしておけば安心? 細かな設定項目が用意されているし、xml書けば自分でカスタマイズもOKらしい。 あんまり使いたいとは思わないけれど、いざという時のための保険として・・・。

sedが便利すぎる

久々にsedの活躍の場 大量のWebを扱う話は継続しております。 よくよく、調べてみると恐ろしげな記述があちこちに… 表があって、その中に金額の一覧が作られているんだけど、ソースコードを見ると <td>¥500-</td> とか書かれているわけですよ。 でもって、これをレンダリングすれば、[ \500- ] となるわけです。 ちなみに、[ ] が表だと思ってください。 これが、1ページに40ヶ所程度。×60ページ。 やる気が失せますわ…。 そこで、sedの出番となるわけです。 何がしないといけないのかというと、 「¥」→「&yen;」に置き換えれば良いだけの話。 これならワンライナーでOKっぽい。 sed -i -e 's/\\/\&yen;/g' www/*/*.html 結局、これだけですね。 ファイル全体で置換して、結果をファイルに上書き保存。 でもって、フォルダが60個ほど分けて保存されているので、その中のhtmlファイルを指定してやればOK。 実際に実行してやると、ほんの1秒足らずで終了してくれます。 こんなの手作業でやる気にならないもんね〜。 テストする時間を入れても、10分もかかっていないので、良い選択をしたなとw こういった処理はスクリプト書くより、sedやawkの方が早いですゎ。 でも、エディタやらGUIベースのツール使ってたりすると、何時間もかけちゃったりするんだろうな、普通は。

MavericksからYosemiteへアップグレード

イメージ
昨夜のAppleの発表後 昨夜2時の発表をリアルタイムで観ていたら、朝寝坊してしまいました・・・。 さて、Yosemiteの配布が金曜から始まる(ってもう金曜だけど…)ということで、午前中に作業をやって、キリをつけて早速インストールする事にした。 まぁ、人柱的な意味もあるけれど、このチャンスを逃すと次はいつになるかわからないので、思い切って実施。 前準備 すべてのアプリのアップデートを完了しておく。(iTunes内のAppも) もう使っていないソフトや不要なものは削除。 重要なものは最悪の場合どこからでも利用できるようにクラウド上にコピー。 Timemachineで即座にバックアップの作成。 と、ここまでやっておけば一安心。 無線LANは、万が一のことがあるので、有線に切り替え。 さて、アップグレードしてみます。 いろいろな情報が書かれています。 もっとダウンロードに時間がかかるかと思ったけれど、案外空いているのか、Appleが増強しているのか、サクッと落ちました。 すぐ再起動するよと言ってくるので、どんどん進めていきます。 残り時間あと2分になってから、異常に時間がかかりました。 少し昼寝が出来るほどでした。多分、一生懸命書き換えをしているんでしょうね。 もう少しプログレスバーの出来をよくして欲しいですな。 多分1時間くらいは表示が2分のまま経過。 その間、HDDはカリカリと鳴っていたので、安心はしていましたが、時間とともに不安になりましたゎ。 無事、起動してくれたので、AppleIDのパスワードを入れて完了。 いくつか、同意するか?とか聞かれますが、問題なしです。 左上のボタンが…iOSちっくでフラットデザインになっています。 起動後、AppStoreでアップデートを確認してみたら、すでに結構な量出ていました。 iWork関連なんかは結構早く完了。iPhotoはやや時間がかかったものの無事終了。 Command Line Toolsは結構時間がかかりました。 感覚的には、Mavericksよりキビキビとした動作をするような感じです。 また、「ことえり」が無くなり、日本語入力は別のプログラムに。 MeCabを利用したシステ...

perlで不要なタグを削除

素人すぎですよ 製作途中で放置されているサイトの依頼を受けて、少し前からチェック等していましたが…。 確かに、それなりに表示されているものの、中身がひどくてメンテナンスをどうやるか悩むレベル。 いろんな情報を提供する目的なんだろうけど、元のファイルをコピーして書きなおしている感じで、DBも使わず、サーバサイドで処理もせず、CSSもほぼなし。 ざっと300ファイル(全部html)で、やたらと全角スペースでレイアウトされているstaticなページ。 これを直すのは正直嫌です。 しかも、各ファイルの先頭に <script type="text/javascript"> if ((navigator.userAgent.indexOf('iPhone') > 0 && navigator.userAgent.indexOf('iPad') == -1) || navigator.userAgent.indexOf('iPod') > 0 || navigator.userAgent.indexOf('Android') > 0) { location.href = '/smartphone/'; }</script> そして、smartphoneフォルダには何もない。 だから、PCと同じページを見に来るとNot Found多発地帯という地雷まで完備。 この設計意味が分かりません。変更が発生した場合は、どうするつもりだったんでしょう??? 1つずつ直すのか?それとも、何かジェネレータプログラムが作ってあって、ガシガシと吐き出しているのだろうか? スマートフォンでも見えるように修正 まずは、現状のhtmlを見せれば、not foundは解決するので、scriptを無効にしたい。 とはいっても、300も1つ1つ直すのはコンピュータ使いのやることじゃない。 ここはperlでサクッと処理したい所。 調べてみると、TreeBuilderが良さそう。こんなことがなきゃ、この手のライブラリを使うことも無いだろうなんて思いながら、テストコードを書いてみる。  # perl -MCPA...

findで条件に合わないものを探す

findってあんまり使わないけど… 今頃になって、知ったというか、調べたというか…。 一体何年使っているんだと言われそうなくらい初期の頃から使っているのに、こんな使い方したことなかったなぁと、自分でも驚いた。 忘れないとは思うけど、きっと同じような人がいるだろうと思うので、書いておく。 これまでの使い方 いままで、findを使う時って、 特定の拡張子が含まれている サイズが1MB以上 何日前より古いファイル 30分以内に編集したファイル なんて使い方が多かった。 でもって、中身を検索するならgrepだし…。 もちろん、パイプも使うし、xargsも使ってきた。 今回、はて?と考えた事 今回相談があって、LibreOfficeで編集ができないファイルがある。とな…。 調べてみると、オーナーがnobodyになっている。 ちょいちょい不具合もあるので、根本原因は調査中だけど、編集できないのは困るというので、急ぎで修正する必要がある。 さて、user_aのホームフォルダ以下で、user_aがユーザではないファイルを探す…。 まず、思いついたのは findだよなぁと…。 # find /home/user_a -user user_a これだと、user_aが所有者のファイルがリストアップされる。 あれ? 否定はどうするんだ???と grep -v はよく使うけれど、findの条件否定って、よくよく考えると使ったことがないような気がする。(20年近くUNIX系触っているのに…) まずは、Helpだよね。 $ find --help 使用法: find [-H] [-L] [-P] [-Olevel] [-D help|tree|search|stat|rates|opt|exec] [path...] [expression] デフォルトのパスはカレントディレクトリです。デフォルトの評価式 (expression) は -print です。評価式は演算子、オプション、テストおよびアクションで構成されます。 演算子 (優先順位は降順です。特に指定がない場合は -and が暗黙的に使用されます):      ...

久しぶりで、使い方を忘れてた…(Perl)

Perlでプログラムをガシガシと 昨年納品したプログラムの、追加機能の要求が上がったので、見直しを行っていた。 今回は、DBを使うほど件数が増えそうにもない。 履歴を見て登録されているユーザか、そうでないかを判別するだけなので、ハッシュをファイルに紐付けて、簡易のDBとして使うことにする。  昔なら、メモリがパンクするんじゃ?とかディスク遅いっすとか思ったりして躊躇するんだろうけど、今どきはドンドンメモリ使っちゃおう!ファイル使っちゃおう!なんて思ったりもする。 さて、前回利用したモジュールは Jcode; MIME::Parser; MIME::WordDecoder; File::Basename; File::Path; Fcntl; File::Temp; 書き出してみるとこんなにもあった。 でもって、今回新たに Storable; 当然、稼働しているプログラムなので、直接いじるわけにはいかない。 とりあえず、ローカルでテストをする。 ソースを取り出して、修正内容を細かく分割。 それぞれテストして、組み立て…。 と、最初のテストで躓いた。 ローカルの環境が、この春に14.04で準備したNewマシンなので、モジュールが入っていない! モジュールのインストール そもそも、最初のuse Jcode;でエラー吐いているし… ということで、インストールしようとしたが、コマンドを全く思い出せない。 あれれ? どうやら老化と共にやってくるアレか? # perl -MCPAN -e shell これが思い出せずに、仕方なくググりました。 いやぁ、外部記憶に入れておいて良かったゎ(泣) というか、内部記憶から消去されている模様。 忘れないように、自分を戒めるために記録しておく。 作業自体は、コマンド入力して完了するのに1分もかからないというのに、思い出そうとした時間の方が長いとは…。 root@X200:~# perl -MCPAN -e shell CPAN.pm requires configuration, but most of it can be done automaticall...

LibreOfficeのUpdateでエラー発生

Ubuntu上でのLibreOffice 現在、顧客にも使ってもらっていることも有り、Linuxマシン上ではLibreOfficeを、MacでもLibreOfficeをメインで使うようにしている。 まぁ、たまにはWordやExcelも使うのだけれど、慣れればそれほど問題もない。 しかも、ちょくちょくUpdateが出て、少しずつ不具合が改善されたり機能UPしてくれるので、楽しみでもある。 今は、PPAからbackport版を入れているので、最新のバージョンで動かしている。 今回久々に仕事が一段落して、Updateをかけるタイミングが出来たので実行するとエラーが…。 依存関係が解消できないよ…って言われても、別段おかしな処理もしていないし、いつも使っているマシンなので、使えなくなるもの困る。 言われるように apt-get -f install を実行すると、解決するどころじゃない。 root@hostname:~# apt-get -f install パッケージリストを読み込んでいます... 完了 依存関係ツリーを作成しています                 状態情報を読み取っています... 完了 依存関係を解決しています ... 完了 以下のパッケージが自動でインストールされましたが、もう必要とされていません:   libvisio-0.0-0 libmspub-0.0-0 libcdr-0.0-0 liborcus-0.6-0 これらを削除するには 'apt-get autoremove' を利用してください。 以下の特別パッケージがインストールされます:   libreoffice-base 提案パッケージ:   libreoffice-gcj libreoffice-report-builder 以下のパッケージはアップグレードされます:   libreoffice-base アップグレード: 1 個、新規インストール: 0 個、削除: 0 個、保留: 0 個。 3 個のパッケージが完全にインストールまたは削除されていません。...