「
clustal-omegaを用いてアライメントを実行
」を編集中
2023年5月17日 (水) 15:03時点における
MSY-07
(
トーク
|
投稿記録
)
による版
(セクションの追加、改行の修正)
(
差分
)
← 古い版
|
最新版
(
差分
) |
新しい版 →
(
差分
)
ナビゲーションに移動
検索に移動
警告: このページの古い版を編集しています。
公開すると、この版以降になされた変更がすべて失われます。
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、さまざまなメリットもあります。
スパム攻撃防止用のチェックです。 決して、ここには、値の入力は
しない
でください!
== 概要 == 開いているファイル内の配列データを、clustal-omegaを使ってアライメントにかけます。 clustal-omegaのサイトには、'''"The last alignment program you'll ever need"'''とのことなので、いまなりにはclustal-omegaがいいようです。 さくっと、アライメントを確認したいときに使ってください。 [[ファイル名を引数にしてアプリ起動]]の応用例です。 == 注意事項 == '''要cllustal-omega''' [http://www.clustal.org/omega/ http://www.clustal.org/omega/] '''使用前に"CLUSTALO_DIR"を必ず設定して下さい。''' ダウンロードしたclustal-omegaを解凍して出てきたフォルダの中に"tmp"という名前のフォルダを作ってください。 == ソースコード == <syntaxhighlight lang="javascript"> #title="clustal-omegaを用いてアライメントを実行" #tooltip="clustal-omegaを用いてアライメントを実行します。*.alnファイルを作成しそれを開きます" // ----------------------------------------------------------------------------- // clustal-omegaを用いてアライメントを実行 // // suke // // 要clustal-omega // http://www.clustal.org/omega/ // info : https://www.ebi.ac.uk/Tools/msa/clustalo/ // ----------------------------------------------------------------------------- (function(){ const fso = new ActiveXObject('Scripting.FileSystemObject'); const sh = new ActiveXObject('WScript.Shell'); const MERY_DIR = fso.GetParentFolderName(window.Editor.FullName); // clustal-omegaを導入したフォルダへ移動する const CLUSTALO_DIR = fso.BuildPath('ここにClustal-omegaのフォルダのパスを指定してください'); // カレントディレクトリを移動する sh.CurrentDirectory = CLUSTALO_DIR; // 実行ファイル const CLUSTALO = 'clustalo.exe'; // ファイルが保存されていない場合の保存先 const TMP_DIR = fso.BuildPath(CLUSTALO_DIR,'tmp'); //clustaloのパスが正しいか確かめる if ( !(fso.FileExists(CLUSTALO)) ){ alert('clustalo.exeへのパスが間違ってます。'); return ; } if ( !(sh.Exec(CLUSTALO + ' -h').StdOut.ReadAll().split('\n')[0].match(/^Clustal Omega.*/))){ alert('clustalo.exeではなさそうです。'); return ; } //TMP_DIRにフォルダがあるか確かめ、なければ作る if (!(fso.FolderExists(TMP_DIR))){ alert(TMP_DIR + '\nが無いようなので作っときますね'); fso.CreateFolder(TMP_DIR); } // 実行確認 const isExec = Confirm('ファイルを保存してアライメントを実行しますか?'); if(!isExec){return}; // 現在のファイル名を取得 // 取得できなければ、勝手に作って、書き込む const inputFile = document.FullName || fso.BuildPath(TMP_DIR, (new Date().getTime() + '.txt')); document.Save(inputFile); const alignmentFile = fso.BuildPath( fso.GetParentFolderName(inputFile), fso.GetBaseName(inputFile) + '.aln'); // コマンドラインで渡す文字列を指定 // see clustalo.exe -h let cmdline = CLUSTALO; cmdline = cmdline + ' -i "' + inputFile + '"'; // Multiple sequence input file cmdline = cmdline + ' -o "' + alignmentFile +'"'; // Multiple sequence alignment output file cmdline = cmdline + ' --outfmt=clustal'; // MSA output file format(clustal) cmdline = cmdline + ' --force'; // Force file overwriting cmdline = cmdline + ' -v'; // Verbose output // 実行 const execResult = sh.Exec(cmdline); while (execResult.Status !== 0){sh.Sleep(100)} // 出力メッセージを表示 const err_msg = execResult.StdErr.ReadAll(); const std_msg = execResult.StdOut.ReadAll(); if (err_msg !== ''){ alert('エラーが発生しました\n' + err_msg); return; } if (std_msg !== ''){ alert('【実行結果】\n' + std_msg); } // アライメントの結果ファイルを開く editor.OpenFile(alignmentFile, meEncodingNone, meOpenAllowNewWindow); })(); </syntaxhighlight>
編集内容の要約:
MeryWikiへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MeryWiki:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の数式を計算してその答えを欄に入力してください (
ヘルプ
):
いちたすには =
キャンセル
編集ヘルプ
(新しいウィンドウで開きます)
スポンサーリンク
ナビゲーション メニュー
個人用ツール
ログインしていません
トーク
投稿記録
アカウント作成
ログイン
名前空間
ページ
議論
日本語
表示
閲覧
編集
履歴表示
その他
検索
スポンサーリンク
スポンサーリンク
案内
メインページ
ヘルプ
よくある質問
マクロリファレンス
マクロライブラリ
プラグインライブラリ
構文ファイル
テーマ
寄付・開発支援
練習用ページ
開発室
開発者のブログ
ツール
スポンサーリンク