No.4ベストアンサー
- 回答日時:
FileSystemObjectを使ったらどうですか?
拡張子&ファイル名を取得する方法を書いときます
参照設定で「Microsoft Scripting Runtime」を参照します。
'拡張子のみ取得
Function hoge1(strPath As String) As String
Dim fso As New FileSystemObject
hoge1=fso.GetExtensionName(strPath)
End Sub
'ファイル名のみ取得
Function hoge2(strPath As String) As String
Dim fso As New FileSystemObject
hoge2=fso.GetFileName(strPath)
End Sub
じゃ、そゆことで。
ありがとうございます
そうか、FileSystemObjectか・・・
存在を忘れていました(笑)
参考になりました。早速使わせていただきますw
No.3
- 回答日時:
お疲れ様です。
ファイル名の後ろから"."を探せばいいのではないでしょうか。
(例
Dim ファイル名 As String
Dim 名前 As String
Dim 拡張子 As String
Dim 位置 As Long
ファイル名 = "AIUEO.TXT"
位置 = InStrRev(ファイル名, ".") '// 後ろから文字を検索
名前 = Left$(ファイル名, 位置 - 1) '// 名前が入る
拡張子 = Right$(ファイル名, Len(ファイル名) - 位置) '// 拡張子が入る
(結果
名前 = "AIUEO"
拡張子 = "TXT"
間違っていたらごめんなさい。
おはようございます
お礼が遅くなって申し訳ありません!
InStrRevっていう関数があるんですねw
知らなかったな~^^
私はLen関数で文字列長を取得してから、Loopで回してました(笑)
勉強になりました!
No.2
- 回答日時:
拡張子を認識するためのAPI関数があります。
ファイルのフルパスでもOK
'拡張子のピリオドを<<vbNullChar>>に変換するAPI関数
Private Declare Sub PathRemoveExtension Lib "shlwapi.dll" Alias "PathRemoveExtensionA" (ByVal pszPath As String)
Sub Main()
Const FILE1 As String = "c:\test\index.html"
Const FILE2 As String = "c:\test\index.html.doc.txt.wav"
Const FILE3 As String = "index"
Const FILE4 As String = "index.html.doc.txt.wav.ウィルス"
Dim wkStr1 As String
Dim wkStr2 As String
Call GetGetGet(FILE1, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE1 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Call GetGetGet(FILE2, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE2 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Call GetGetGet(FILE3, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE3 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Call GetGetGet(FILE4, wkStr1, wkStr2)
MsgBox _
"ファイル名:[" & FILE4 & "]" & vbNewLine & _
"ファイル :[" & wkStr1 & "]" & vbNewLine & _
"拡張子 :[" & wkStr2 & "]"
Exit Sub
End Sub
Function GetGetGet(ByVal inFileName As String, ByRef outFileName As String, ByRef outKakutyousi As String)
Dim valWork As Variant
'戻りパラメータ初期化
outFileName = ""
outKakutyousi = ""
'拡張子を<<vbNullChar>>に変換
Call PathRemoveExtension(inFileName)
'vbNullCharで切り分ける
valWork = Split(inFileName, vbNullChar)
'配列の先頭がファイル名
outFileName = valWork(0)
'拡張子が存在してない時は、以下を通らない
If UBound(valWork) > 0 Then
outKakutyousi = valWork(1)
End If
End Function
御有難う御座りまスル!!
ムムム・・・・・・・・
何か非常に難しいですな
拙者の存ぜぬ関数なる物が
多分に表記されておる為か
理解に時が必要じゃw
拙者の現在の習熟能力では
把握出来ぬ故、暫しの時を
くだされ、勉学に勤しんで
みるとしよう・・・(笑)
VBって奥が深いですね!
まだまだ勉強が必要です。
皆さんホントにどうもです
o(o|o)/ (V)o\o(V)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドプロンプトの「%1」と...
-
[DOS] コピー先に同じファイル...
-
バッチファイルで、iniファイル...
-
.batでファイル名から抽出して...
-
フォルダ内の更新日時が一番新...
-
ftp処理でmove(移動)を行いたい
-
コマンドプロンプトで変数が数...
-
ファイル名の頭5桁と同名のフォ...
-
コマンドプロンプトでファイル...
-
ExcelVBAのDirでスペース含むフ...
-
【Access】エクスポート時のフ...
-
バッチコマンドでファイル名の...
-
テキストファイルのファイル名...
-
ファイル名を変更して移動させ...
-
バッチ処理で16進数でファイル...
-
DOSのバッチ作成について‐FORの...
-
バッチにて複数のcsvファイルを...
-
VBA GetAttrについて教えてくだ...
-
VBでテキスト形式のファイル...
-
エクセルVBAを使用してJPGファ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンドプロンプトの「%1」と...
-
コマンドプロンプトでファイル...
-
バッチファイルで、iniファイル...
-
ftp処理でmove(移動)を行いたい
-
コマンドプロンプトで変数が数...
-
[DOS] コピー先に同じファイル...
-
ExcelVBAのDirでスペース含むフ...
-
バッチコマンドでファイル名の...
-
フォルダ内の更新日時が一番新...
-
.batでファイル名から抽出して...
-
access,vbaでフォルダ内のファ...
-
【Access】エクスポート時のフ...
-
ファイル名に ” を使うと エク...
-
ファイル名を該当フォルダ内か...
-
VBA GetAttrについて教えてくだ...
-
VBScriptで特別な意味を持つ記...
-
ファイル名の頭5桁と同名のフォ...
-
エクセルVBAを使用してJPGファ...
-
【DOSバッチ開発】末尾のタブの...
-
Windowsコマンドプロンプトで、...
おすすめ情報