VBA関数
Shell関数

Excelマクロで必須のVBA関数を入門・初級・初心者向けに詳細解説
公開日:2013年5月以前 最終更新日:2021-08-14

Shell関数


Shell関数は、実行可能プログラムを実行し、実行が完了するとプログラムのタスク IDを示すバリアント型の値を返します、


プログラムの実行に問題が発生した場合は、0 を返します。

Shell関数

Shell(pathname[,windowstyle])
pathname 必ず指定します。バリアント型 (内部処理形式 String の Variant) の値を指定します。
また、フォルダ、またはドライブを含めて指定できます。
実行するプログラム名と必要な引数名またはコマンド ラインのスイッチを指定します。
windowstyle 省略可能です。実行するプログラムのウィンドウの形式に対応するバリアント型の値を指定します。
Macintoshでは、アプリケーションの実行中に、そのアプリケーションがフォーカスを取得できるかどうかを指定するだけです。
引数 windowstyle を省略すると、プログラムはフォーカスを持った状態で最小化され、実行を開始します。
定数 内容
vbHide フォーカスを持ち、非表示にされるウィンドウ。
vbNormalFocus フォーカスを持ち、元のサイズと位置に復元されるウィンドウ
vbMinimizedFocus フォーカスを持ち、最小化表示されるウィンドウ
vbMaximizedFocus フォーカスを持ち、最大化表示されるウィンドウ
vbNormalNoFocus 最後にウィンドウを閉じたときのサイズと位置に復元されるフォーカスを持たないウィンドウ。
現在アクティブなウィンドウは、アクティブのままです。
vbMinimizedNoFocus 最小化表示されるフォーカスを持たないウィンドウ。
現在アクティブなウィンドウは、アクティブのままです。

使用例

Shell "notepad.exe " & ThisWorkbook.Path & "\使用例テキスト.txt", vbNormalFocus

メモ帳のnotepad.exeは、システムフォルダにありパスが通っているので、ファイル名だけで起動が出来ます。
exeにパスが通っていない場合は、フルパスで指定します。

第121回.SendKeysメソッドとAppActivateステートメント|VBA入門
マクロVBAから直接連携操作できない他のアプリケーションに対しても、VBAのキーコード転送を使って操作することが可能です。SendKeysメソッドを使い、アクティブなアプリケーションにキーコードを転送することで操作します。これは、他のアプリケーションにキーホード入力をすることができるという事です。
第122回.Shell関数|VBA入門
Excelを自動操作するのがマクロVBAの主な使用目的ですが、他のアプリケーションを起動したい場合も時に出てきます。他のアプリケーションを起動する手段としてVBAに標準で用意されているものがShell関数です。VBAの実行結果をテキスト出力しておいて、マクロ終了時に、メモ帳で実行結果を表示するといったようなことが、
VBAでファイルを既定のアプリで開く方法|VBA技術解説
Excelマクロで、エクセル以外のファイルを既定のアプリケーションで開く場合の方法について何通りか解説します、VBAでファイルを単純に開くだけの場合についてになります。ファイルを開いた後に、そのファイルに対して何らかの操作をしたい場合は、対応するアプリケーション毎に個別の対応が必要になりますが、Windowsで開け…


Office VBA リファレンス CreateObject関数


※VBA関数一覧
マクロVBA関数の一覧と解説です、どんな関数があるかは一度は確認しておくとをお勧めいたします。どんな関数があるだけでも知っておけば、詳細の使い方は実際に使うときに調べても良いでしょう。文字列操作…34 分岐…3 型変換…14 データ判定…10 日付時刻…20 配列…6 ファイル操作…14 数学/財務…28 その他……



同じテーマ「VBA関数」の記事

Oct関数

Oct関数は、引数に指定した値を8進数で表すバリアント型(内部処理形式StringのVariant)の値を返します。Oct関数 Oct(number) number 必ず指定します。任意の数式または文字列式を指定します。
Rnd関数
Rnd関数は、単精度浮動小数点数型(Single)の乱数を返します。Rnd関数 Rnd[(number)] number は省略可能です。引数numberには、単精度浮動小数点数型(Single)の数値または任意の有効な数式を指定します。
Round関数
Round関数は、指定された小数点位置で丸めた数値を返します。Round関数 Round(expression[,numdecimalplaces]) expression 必ず指定します。丸めを行う数式を指定します。
InputBox関数
InputBox関数は、ダイアログボックスにメッセージとテキストボックスを表示し、文字列が入力されるか、またはボタンがクリックされると、テキストボックスの内容を返します。InputBox関数 構文 InputBox(prompt[,title][,default][,xpos][,ypos] [,helpfile,
MsgBox関数
MsgBox関数は、ダイアログボックスにメッセージを表示し、ボタンがクリックされるのを待って、ユーザーがどのボタンをクリックされたのかを示す整数を返します。MsgBox関数の構文 MsgBox(prompt[,buttons][,title][,helpfile, context]) 戻り値は、VbMsgBoxRe…
Environ関数
オペレーティングシステム(Windows)の環境変数に関連付けられた文字列を返します。Macintoshでは使用できません。デスクトップのパスやログインしているユーザーの名前を取得できます。IsNull関数の構文 Environ({envstring|number}) envstringまたはnumberのどちらか…
RGB関数
RGB関数は、引数(red,green,blue)の色のRGB値を表す長整数型(Long)の値を返します。RGB関数 RGB(red,green,blue) red 必ず指定します。この名前付き引数は、バリアント型(内部処理形式IntegerのVariant)のデータ形式で指定します。
DoEvents関数
DoEvents関数は、発生したイベントがOSによって処理されるように、プログラムで占有していた制御をOSに渡します。DoEvents関数 構文 DoEvents 説明 開かれているフォームの数を返します。開かれているフォームが無ければ0返します。
CreateObject関数
CreateObject関数は、ActiveXオブジェクトへの参照を作成して返します。CreateObject関数を使う事で、参照設定することなくActiveXオブジェクトを使用できるようになります。つまり、VBAで外部ライブラリを使用する場合にCreateObject関数を使用します。
GetObject関数
ActiveXコンポーネントから提供されたオブジェクトの参照を返します。ファイルパス(フルパスと名前)からオブジェクトの参照を作成したり、既に起動中のオブジェクトを取得する際に使用します。GetObject関数の構文 GetObject([pathname],[class]) pathname 省略可能。
Shell関数


新着記事NEW ・・・新着記事一覧を見る

TRIMRANGE関数(セル範囲をトリム:端の空白セルを除外)|エクセル入門(2024-08-30)
正規表現関数(REGEXTEST,REGEXREPLACE,REGEXEXTRACT)|エクセル入門(2024-07-02)
エクセルが起動しない、Excelが立ち上がらない|エクセル雑感(2024-04-11)
ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.繰り返し処理(For Next)|VBA入門
3.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
4.変数宣言のDimとデータ型|VBA入門
5.RangeとCellsの使い方|VBA入門
6.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
7.セルのクリア(Clear,ClearContents)|VBA入門
8.メッセージボックス(MsgBox関数)|VBA入門
9.条件分岐(Select Case)|VBA入門
10.ブック・シートの選択(Select,Activate)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。


このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ