-
vb.net 教程 4-2 目录操作 DirectoryInfo 2
版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
上一节讲到了使用DirectoryInfo属性获取目录信息,本节讲一下有关DirectoryInfo的几个重要方法:创建、删除、移动
创建目录使用的是 Create() 方法,主要代码如下:
Private Sub btnCreateFolder_Click(sender As Object, e As EventArgs) Handles btnCreateFolder.Click
Dim di As New DirectoryInfo("d:\aa")
If di.Exists Then
txtFolderInfo.Text = "文件夹已经存在"
Exit Sub
End If
di.Create()
txtFolderInfo.Text = "文件夹已经创建"
End Sub
其中判断了目录是否已经存在,如果已经存在那么退出。
删除目录使用的是 Delete()方法,主要代码如下:
Private Sub btnDelFolder_Click(sender As Object, e As EventArgs) Handles btnDelFolder.Click
Dim di As New DirectoryInfo("d:\aa")
If di.Exists Then
Try
di.Delete()
txtFolderInfo.Text = "文件夹已经删除"
Catch ex As Exception
txtFolderInfo.Text = "删除文件夹时发生错误," & ex.Message
End Try
Else
txtFolderInfo.Text = "文件夹不存在"
End If
End Sub
实际上这个代码存在一些问题,如果需要删除的目录中包含子目录或者文件,那么会产生错误。
可以使用重载的Delete()方法完成对包含有子目录或者文件的目录的删除:
Private Sub btnDelFolder2_Click(sender As Object, e As EventArgs) Handles btnDelFolder2.Click
Dim di As New DirectoryInfo("d:\aa")
If di.Exists Then
Try
di.Delete(True)
txtFolderInfo.Text = "文件夹已经删除"
Catch ex As Exception
txtFolderInfo.Text = "删除文件夹时发生错误," & ex.Message
End Try
Else
txtFolderInfo.Text = "文件夹不存在"
End If
End Sub
代码中,di.Delete(True),参数True指明了要删除该目录中的子目录和文件。
移动目录使用的是 MoveTo()方法,主要代码如下:
Private Sub btnMoveFolder_Click(sender As Object, e As EventArgs) Handles btnMoveFolder.Click
Dim di As New DirectoryInfo("d:\aa")
If di.Exists Then
Try
di.MoveTo("d:\dd")
txtFolderInfo.Text = "文件夹已经移动完毕"
Catch ex As Exception
txtFolderInfo.Text = "移动文件夹时发生错误," & ex.Message
End Try
Else
txtFolderInfo.Text = "文件夹不存在"
End If
End Sub
需要注意的是,该方法不支持跨磁盘分区移动,修改代码
di.MoveTo("d:\dd")
为
di.MoveTo("c:\dd")
会产生错误:
学习更多vb.net知识,请参看 vb.net 教程 目录
————————————————
版权声明:本文为CSDN博主「VB.Net」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/uruseibest/article/details/74923460
最新更新
python爬虫及其可视化
使用python爬取豆瓣电影短评评论内容
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比