VBA 操作文件相關(guān)的技巧總結(jié)

'適用于知識(shí)點(diǎn)六的API代碼

Private Declare Function PathFileExists Lib "shlwapi.dll" Alias "PathFileExistsA" (ByVal pszPath As String) As Long

'知識(shí)點(diǎn)一:Path,返回當(dāng)前工作簿路徑

'測(cè)試代碼如下:

Sub getpath()

'定義mypath為字符串

Dim mypath As String

'把當(dāng)前文件路徑賦予給mypath妹懒,注意thisworkbook.path的使用

mypath = ThisWorkbook.Path

'顯示路徑

MsgBox mypath

End Sub

'知識(shí)點(diǎn)二:利用當(dāng)前路徑選擇性打開當(dāng)前文件夾中某xlsx文件

Sub myfile()

'定義mypath為字符串

Dim mypath As String

' 指定路徑

mypath = ThisWorkbook.Path

'打開指定路徑的A工作簿

Workbooks.Open mypath & "\A.xlsx"

End Sub

'知識(shí)點(diǎn)三:返回當(dāng)前文件夾的除了“文件操作”外其他所有xlsx文件名

Sub GetAllFileName()

'定義MyDir為字符串

Dim MyDir As String

'返回當(dāng)前工作簿路徑的Excel文件名稱

MyDir = Dir(ThisWorkbook.Path & "\*.xlsx")

'把MyFile賦予A1

[A1] = "MyFile"

'******************************************

Do

'需要列出的文件名不包含當(dāng)前的“文件操作”的Excel文件捻爷,使用Not...Like 來(lái)判斷

If Not MyDir Like "*文件操作*" Then

'如果不存在,則逐個(gè)填入當(dāng)前文件夾中的Excel文件名稱

Cells(Cells(Rows.Count, 1).End(xlUp).Row + 1, 1) = MyDir

'退出If判斷

End If

'返回匹配路徑的第一個(gè)文件名稱

MyDir = Dir

'避免錯(cuò)誤發(fā)生雷蹂,設(shè)置循環(huán)終止條件為L(zhǎng)en(MyDir)=0铺浇,即判斷文件名是否為空

Loop Until Len(MyDir) = 0

'******************************************

End Sub

'知識(shí)點(diǎn)四:批量刪除文件夾內(nèi)所有類型文件

Sub 批量刪除文件()

'定義變量

Dim fso, fld, fd, F

'調(diào)用Scripting.FileSystemObject

Set fso = CreateObject("Scripting.FileSystemObject")

'返回一個(gè)和指定路徑中文件夾相對(duì)應(yīng)的FSO文件夾對(duì)象

Set fld = fso.getfolder(ThisWorkbook.Path & "\")

'循環(huán)每個(gè)文件夾并刪除

For Each fd In fld.subfolders

fd.Delete

Next

'除了本工作簿文件外却舀,循環(huán)其他每個(gè)文件并刪除

For Each F In fld.Files

If F.Name <> ThisWorkbook.Name Then F.Delete

Next

End Sub

'知識(shí)點(diǎn)五:判斷指定文件是否存在

Sub FileExist1()

'如果當(dāng)前路徑下的B文件的文件名不為空逛漫,則存在黑低,否則不存在

If Dir(ThisWorkbook.Path & "\B.xlsx") <> "" Then

MsgBox "B文件存在!"

Else

MsgBox "B文件不存在!"

End If

End Sub

'知識(shí)點(diǎn)六:判斷指定文件是否存在(API函數(shù))

'*************API代碼判斷存在*******************************************************************

'Private Declare Function PathFileExists Lib "shlwapi.dll" Alias "PathFileExistsA" (ByVal pszPath As String) As Long

Sub FileExist2()

'調(diào)用了PathFileExists這個(gè)API函數(shù)判斷

If CBool(PathFileExists(ThisWorkbook.Path & "\B.xlsx")) Then

MsgBox "B文件存在!"

Else

MsgBox "B文件不存在!"

End If

End Sub

'PathFileExists 既可以判斷本地文件是否存在,又可以判斷遠(yuǎn)程電腦上的文件是否存在酌毡。函數(shù)返回值是個(gè)Long型變量克握,返回兩個(gè)值0,1。1表示文件存在(True),0表示文件不存在(False)

'*************API代碼判斷存在*******************************************************************

'知識(shí)點(diǎn)七:判斷指定文件是否存在(Scripting.FileSystemObject法)

Sub FileExist3()

'定義變量fs

Dim fs

'調(diào)用Scripting.FileSystemObject

Set fs = CreateObject("Scripting.FileSystemObject")

'利用FileExists功能判斷

If fs.FileExists(ThisWorkbook.Path & "\B.xlsx") = True Then

MsgBox "B文件存在!"

Else

MsgBox "B文件不存在!"

End If

End Sub

'知識(shí)點(diǎn)八:列出指定路徑所有子文件夾名稱

Sub GetAllFolderlist()

'定義變量fs阔馋、fld玛荞、fd

Dim fs, fld, fd

'定義i為長(zhǎng)整型

Dim i As Long

'初始化i變量

i = 0

'調(diào)用Scripting.FileSystemObject

Set fs = CreateObject("Scripting.filesystemobject")

'返回一個(gè)和指定路徑中文件夾相對(duì)應(yīng)的FSO文件夾對(duì)象

Set fld = fs.getfolder(ThisWorkbook.Path & "\")

'循環(huán)每個(gè)文件夾

For Each fd In fld.subfolders

'把文件夾名稱賦予B列

Cells(i + 1, 2) = fd.Name

'使用累加器

i = i + 1

Next

End Sub

'知識(shí)點(diǎn)九:獲取文件夾大小

Sub GetF()

'定義變量fs娇掏、fld呕寝、fd

Dim fs, fld, fd

'定義i為長(zhǎng)整型

Dim i As Long

'初始化i變量

i = 0

'調(diào)用Scripting.FileSystemObject

Set fs = CreateObject("Scripting.filesystemobject")

'返回一個(gè)和指定路徑中文件夾相對(duì)應(yīng)的FSO文件夾對(duì)象

Set fld = fs.getfolder(ThisWorkbook.Path & "\")

'循環(huán)每個(gè)文件夾

For Each fd In fld.subfolders

'把文件夾名稱賦予B列

Cells(i + 1, 2) = fd.Name

'關(guān)鍵是fd.size/1024的運(yùn)算

Cells(i + 1, 3) = FormatNumber(fd.Size / 1024, 0) & "KB"

'使用累加器

i = i + 1

Next

End Sub

'知識(shí)點(diǎn)十:復(fù)制文件夾

Sub Copyfile()

'定義變量fso,fs

Dim fso, fs

'調(diào)用Scripting.FileSystemObject

Set fso = CreateObject("Scripting.FileSystemObject")

'取得需要復(fù)制的文件夾對(duì)象

Set fs = fso.getfolder(ThisWorkbook.Path & "\SQL高級(jí)")

'使用copy方法復(fù)制到SQL初級(jí)文件夾中

fs.Copy (ThisWorkbook.Path & "\SQL初級(jí)\")

'顯示成功復(fù)制

MsgBox "OK!"

End Sub

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市婴梧,隨后出現(xiàn)的幾起案子下梢,更是在濱河造成了極大的恐慌,老刑警劉巖塞蹭,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件孽江,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡番电,警方通過(guò)查閱死者的電腦和手機(jī)岗屏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門辆琅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人这刷,你說(shuō)我怎么就攤上這事婉烟。” “怎么了暇屋?”我有些...
    開封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵似袁,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我咐刨,道長(zhǎng)昙衅,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任定鸟,我火速辦了婚禮而涉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘仔粥。我一直安慰自己婴谱,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開白布躯泰。 她就那樣靜靜地躺著谭羔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪麦向。 梳的紋絲不亂的頭發(fā)上瘟裸,一...
    開封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音诵竭,去河邊找鬼话告。 笑死,一個(gè)胖子當(dāng)著我的面吹牛卵慰,可吹牛的內(nèi)容都是我干的沙郭。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼裳朋,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼病线!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起鲤嫡,我...
    開封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤送挑,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后暖眼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惕耕,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年诫肠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了司澎。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片欺缘。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖挤安,靈堂內(nèi)的尸體忽然破棺而出浪南,到底是詐尸還是另有隱情,我是刑警寧澤漱受,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布络凿,位于F島的核電站,受9級(jí)特大地震影響昂羡,放射性物質(zhì)發(fā)生泄漏絮记。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一虐先、第九天 我趴在偏房一處隱蔽的房頂上張望怨愤。 院中可真熱鬧,春花似錦蛹批、人聲如沸撰洗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)差导。三九已至,卻和暖如春猪勇,著一層夾襖步出監(jiān)牢的瞬間设褐,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工泣刹, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留助析,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓椅您,卻偏偏與公主長(zhǎng)得像外冀,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子掀泳,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 本例為設(shè)置密碼窗口 (1) If Application.InputBox(“請(qǐng)輸入密碼:”) = 1234 Th...
    浮浮塵塵閱讀 13,620評(píng)論 1 20
  • 文件系統(tǒng)模塊是一個(gè)封裝了標(biāo)準(zhǔn)的 POSIX 文件 I/O 操作的集合雪隧。通過(guò)require('fs')使用這個(gè)模塊。...
    保川閱讀 774評(píng)論 0 0
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程开伏,因...
    小菜c閱讀 6,365評(píng)論 0 17
  • 個(gè)人學(xué)習(xí)批處理的初衷來(lái)源于實(shí)際工作膀跌;在某個(gè)迭代版本有個(gè)BS(安卓手游模擬器)大需求遭商,從而在測(cè)試過(guò)程中就重復(fù)涉及到...
    Luckykailiu閱讀 4,702評(píng)論 0 11
  • Given a nested list of integers represented as a string, ...
    matrxyz閱讀 331評(píng)論 0 0