「
CSV/TSVでアクティブ列選択
」を編集中
2024年12月27日 (金) 10:35時点における
Yuko
(
トーク
|
投稿記録
)
による版
(
差分
)
← 古い版
|
最新版
(
差分
) |
新しい版 →
(
差分
)
ナビゲーションに移動
検索に移動
警告: このページの古い版を編集しています。
公開すると、この版以降になされた変更がすべて失われます。
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、さまざまなメリットもあります。
スパム攻撃防止用のチェックです。 決して、ここには、値の入力は
しない
でください!
== 概要 == このマクロは、CSVファイル内でアクティブな列を選択するためのものです。現在のカーソル位置を基準に、対応する列を自動的に全て選択します。 == 注意事項 == * Mery Ver 3.7.9 で動作確認しています。 == 使い方 == # MeryでCSVファイルを開く # 選択したい列にカーソルを移動させる # このマクロを実行すると、カーソル位置に対応する列が全て選択される === ソースコード === <syntaxhighlight lang="javascript"> #title = "CSV/TSV でアクティブ列選択" var CSV_ID = 1; var TSV_ID = 2; var doc = document; var sel = doc.selection; main(); function main() { // 現在の列位置を取得 var actX = sel.GetActivePointX(mePosLogical); var actY = sel.GetActivePointY(mePosLogical); var line = doc.GetLine(actY); var lineArray = line.split(""); var leftString = lineArray.slice(0, actX - 1).join(""); // CSVかTSVか判定 var menu = createContextMenu(); menuTrack = menu.Track(0); // メニュー選択がキャンセルされた場合は終了 if (menuTrack === 0) return; var fieldCount = 0; var pattern = ""; if (menuTrack === CSV_ID) { // CSVの場合 // フィールド数を計上 // ダブルクォート囲みも考慮する var inDoubleQuote = false; for (var i = 0; i < leftString.length; i++) { if (leftString[i] == '"') { inDoubleQuote = !inDoubleQuote; } if (!inDoubleQuote && leftString[i] == ',') { fieldCount++; } } // 検索パターン if (fieldCount == 0) { pattern = '^([^,]*|"[^",]*")'; } else { pattern = '(?<=^([^,]*,|"[^",]*",){' + fieldCount + '})([^,]*|"[^",]*")'; } } else { // TSVの場合 // フィールド数を計上 fieldCount = leftString.split("\t").length - 1; // 検索パターン if (fieldCount == 0) { pattern = '^[^\\t]*'; } else { pattern = '(?<=^([^\\t]*\\t){' + fieldCount + '})[^\\t]*'; } } sel.Find(pattern, meFindReplaceRegExp + meFindAll + meFindKeepOptions); } function createContextMenu() { const menu = CreatePopupMenu(); menu.Add("CSV でアクティブ列選択 (&C)", CSV_ID); menu.Add("TSV でアクティブ列選択 (&T)", TSV_ID); return menu; } </syntaxhighlight>
編集内容の要約:
MeryWikiへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
MeryWiki:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
このページを編集するには、下記の数式を計算してその答えを欄に入力してください (
ヘルプ
):
いちたすには =
キャンセル
編集ヘルプ
(新しいウィンドウで開きます)
スポンサーリンク
ナビゲーション メニュー
個人用ツール
ログインしていません
トーク
投稿記録
アカウント作成
ログイン
名前空間
ページ
議論
日本語
表示
閲覧
編集
履歴表示
その他
検索
スポンサーリンク
スポンサーリンク
案内
メインページ
ヘルプ
よくある質問
マクロリファレンス
マクロライブラリ
プラグインライブラリ
構文ファイル
テーマ
寄付・開発支援
練習用ページ
開発室
開発者のブログ
ツール
スポンサーリンク