当前位置: 首页 > news >正文

中国矿山建设网站郑州手机网站

中国矿山建设网站,郑州手机网站,深圳微商城网站建设,网络管理系统设备日期:2023年3月10日 作者:Commas 签名:(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释:如果您觉得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方&#xf…

日期:2023年3月10日
作者:Commas
签名:(ง •_•)ง 积跬步以致千里,积小流以成江海……
注释:如果您觉得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^
1.01365 = 37.7834;0.99365 = 0.0255
1.02365 = 1377.4083;0.98365 = 0.0006


在这里插入图片描述


文章目录

  • 一、前言
  • 二、设置与取消文件只读权限
  • 三、判断文件只读
  • 四、实现过程


一、前言

当一个文件(WordExcelPPT等等)编辑的差不多了,准备保存的时候,哟,好家伙,发现该文件权限设置为只读(readonly)了,无法保存,心情突然没那么美丽了。其实很简单解决这个问题,如下所示:

在这里插入图片描述

右键选择“属性”→取消“只读”的勾选,那么example.docx文件就取消只读,可以正常保存了。另外还有什么压缩传输法文件另存法微信降级法等等,虽然可以解决问题,但是也太不方便了。

后面排查发现,原来是最近微信更新后出现的问题——微信传输的文件均被设置成了只读(readonly)权限,给出的说法是为了防止文件信息在网络传输过程中被篡改。但是也太不方便了吧,作为一名技术不能忍,于是乎搞出一个小程序chmod.exe,将这个exe放在微信下载文件夹下面,运行就可以把整个文件夹中所有的文件取消只读了,看下效果吧:

  • 双击运行,效果如下:在这里插入图片描述
  • 再次双击运行,效果如下:
    在这里插入图片描述

好了,话不多说,我们接下来讲讲如何实现吧……

最后面放了程序与源码的下载地址^ - ^

二、设置与取消文件只读权限

VB6中的VBA库提供了一个方法SetAttr(),可以设置文件的读写等等权限。

语法:

VBA.SetAttr(PathName As String,Attributes As VbFileAttribute)

SetAttr(PathName As String,Attributes As VbFileAttribute)
  • PathName:必要参数。需要修改只读属性的文件路径或目录路径;
  • Attributes:必要参数。常数或数值表达式,其总和用来表示文件的属性;

attributes 参数设置可为:

常数描述
vbNormal0常规(缺省值),可读可写
vbReadOnly1只读
vbHidden2隐藏
vbSystem4系统文件
vbArchive32上次备份以后,文件已经改变

设置只读示例:

'set the file readoly
Call VBA.SetAttr(App.Path & "\example.txt",vbReadOnly)

'set the file readoly
Call VBA.SetAttr(App.Path & "\example.txt",1)

取消只读示例:

'cancel the file readonly
Call VBA.SetAttr(App.Path & "\example.txt", vbNormal)

'cancel the file readonly
Call VBA.SetAttr(App.Path & "\example.txt", 0)

三、判断文件只读

VB6中的VBA库提供了一个方法GetAttr(),可以设置文件的读写等等权限。

语法:

VBA.GetAttr(PathName As String) As VbFileAttribute

GetAttr(PathName As String) As VbFileAttribute
  • PathName:必要参数。需要修改只读属性的文件路径或目录路径;
  • VbFileAttribute:返回值是一个 十进制Integer,此为一个文件、目录、或文件夹的属性值总和

GetAttr 返回的值,是下面这些属性值的总和:

常数值(十进制)值(二进制)描述
vbNormal00常规
vbReadOnly11只读
vbHidden210隐藏
vbSystem4100系统文件
vbDirectory1610000目录或文件夹
vbArchive3210000上次备份以后,文件已经改变
vbalias641000000指定的文件名是别名

特别说明

若要判断是否设置了某个属性,在 GetAttr 函数想要得知的属性值之间使用 And 运算符与逐位比较。如果所得的结果不为零,则表示设置了这个属性值,即:

result = GetAttr(PathName) And VbFileAttribute
  • 如果 result <> 0 ,那么表示设置 VbFileAttribute 权限;
  • 如果 result = 0 ,那么没有设置 VbFileAttribute 权限;

只读示例:

Dim result As Integer
result = GetAttr(App.Path & "\example.txt", 0) And vbReadOnly
If result <> 0 ThenDebug.Print "文件设置了只读权限"
ElseDebug.Print "文件未设置只读权限"
End If

只要result <> 0,就表示文件设置了只读权限,其中用到了一个【And 运算符与逐位比较 】知识点,如果读者感兴趣,那么到时候再出一期详细讲讲吧,这里展开讲解的话,可以话题就跑偏了。

上述判断文件权限,大部分习惯高级语言的小伙伴们都不太适应吧,所以我将其封装了下,健康绿色,可以放心食用,如下所示:

Private Function CheckFileReadOnly(ByVal sFilePath As String) As Boolean
On Error Resume Next
'函数说明:判断文件是否为只读
'创建作者:Commas
'创建时间:2022-02-16
'修改时间:
'------数据格式说明------
'sFilePath:文件路径
'------数据格式说明------CheckFileReadOnly = FalseIf sFilePath <> "" ThenIf Dir(sFilePath, vbDirectory + vbNormal + vbArchive + vbHidden + vbReadOnly + vbSystem) <> "" ThenIf (VBA.GetAttr(sFilePath) And vbReadOnly) <> 0 ThenCheckFileReadOnly = TrueEnd IfEnd IfEnd If
End Function

四、实现过程

现在我们实现的是一个文件的权限设置,如果就这么去取消只读权限,那还不如直接右键属性直接取消来的快,所以需要用到目录遍历(如果想详细了解这方面的知识,可以看我的另一篇博文《VB6遍历目录(文件夹和文件)》)。

首先,我们封装一下单个文件的取消只读权限

Private Function CancelFileReadOnly(ByVal sFilePath As String) As Boolean
On Error Resume Next
'函数说明:文件取消只读
'创建作者:Commas
'创建时间:2022-02-16
'修改时间:
'------数据格式说明------
'sFilePath:文件路径
'------数据格式说明------Err.ClearVBA.SetAttr sFilePath, vbNormalIf Err <> 0 ThenCancelFileReadOnly = FalseErr.ClearElseCancelFileReadOnly = TrueEnd If
End Function

然后,我们获取路径下的所有目录(文件夹目录+文件目录)

Set clnDir = GetAllDir(sFindPathName)

接着,我们遍历目录clnDir来取消文件只读

For i = 1 To clnDir.CountsCurFilePath = clnDir.Item(i)'判断文件是否未只读If CheckFileReadOnly(sCurFilePath) ThensCurFileName = Mid(sCurFilePath, InStrRev(sCurFilePath, "\") + 1)'取消文件只读权限If CancelFileReadOnly(sCurFilePath) ThenclnOK.Add sCurFileNameElseclnFail.Add sCurFileNameEnd IfEnd If
Next i

最后,将遍历过程封装成函数,即批量取消只读权限(BatchCancelFileReadOnly

Private Function BatchCancelFileReadOnly(ByVal sFindPathName As String) As Boolean
On Error Resume Next
'函数说明:文件取消只读
'创建作者:Commas
'创建时间:2022-02-16
'修改时间:
'------数据格式说明------
'sFindPathName:文件夹路径
'------数据格式说明------Dim sCurFileName As String, sCurFilePath As String, i As LongDim clnOK As New Collection, clnFail As New Collection, clnDir As New Collection' 获取查询路径下所有目录(包括子孙)Set clnDir = GetAllDir(sFindPathName)For i = 1 To clnDir.CountsCurFilePath = clnDir.Item(i)'判断文件是否未只读If CheckFileReadOnly(sCurFilePath) ThensCurFileName = Mid(sCurFilePath, InStrRev(sCurFilePath, "\") + 1)'取消文件只读权限If CancelFileReadOnly(sCurFilePath) ThenclnOK.Add sCurFileNameElseclnFail.Add sCurFileNameEnd IfEnd IfNext iIf clnFail.Count = 0 ThenBatchCancelFileReadOnly = TrueElseBatchCancelFileReadOnly = FalseEnd IfDim sMsg As StringIf clnOK.Count > 0 Or clnFail.Count > 0 ThenaddMsg sMsg, "******操作完成,详情如下******"addMsg sMsg, "执行路径:" & sFindPathNameaddMsg sMsg, ""End If'okIf clnOK.Count > 0 ThenaddMsg sMsg, ""addMsg sMsg, "@@@@已取消【只读】的文件如下所示:"End IfFor i = 1 To clnOK.CountaddMsg sMsg, clnOK(i)Next'failIf clnFail.Count > 0 ThenaddMsg sMsg, ""addMsg sMsg, "@@@@取消【只读】失败的文件如下所示:"End IfFor i = 1 To clnFail.CountaddMsg sMsg, clnFail(i)NextIf sMsg = "" Then sMsg = "经检查,【路径" & sFindPathName & "】没有【只读】文件"MsgBox sMsg
End Function

调用示例:

Sub Main()Dim sPath As String'VBA.Command$ 也可以从命令行参数提取path,这里暂时没有实现sPath = App.PathDebug.Print BatchCancelFileReadOnly(sPath)
End Sub

顺便提一嘴,还可以做一个计时器,定时执行取消只读权限;或者监听文件变化,再执行批量取消,这样看上去就会更加便捷了,这个实现就留给聪明的你啦^ - ^


一、下载地址:

  • 免费白嫖:https://download.csdn.net/download/qq_35844043/87548631
  • 积分下载:https://download.csdn.net/download/qq_35844043/87548735

二、源码分享:

GitCode地址:https://gitcode.net/qq_35844043/vb6/-/tree/master/


版权声明:本文为博主原创文章,如需转载,请给出:
原文链接:https://blog.csdn.net/qq_35844043/article/details/129420874

http://www.yayakq.cn/news/842252/

相关文章:

  • 公司网站建设的请示西安网站建设西安
  • wordpress仿站抓取软件配置 wordpress
  • 全国网站备案织梦 xml网站地图
  • 邢台高端网站建设公司学校建设网站的目的和意义
  • 宝安有效的网站制作北京网站建设hj华网天下
  • 稳定的网络建站咨询电话设计方案英文
  • 跟公司产品做网站免费创建个人网站
  • 外贸网站建设信息大自然的网站设计
  • 建设部监理资质申报网站wordpress编辑器文件
  • 网站制作要求网络维护服务合同模板
  • 台州做网站哪家公司好好的平面网站模板
  • 网站建设的基础常识专业的天津网站建设
  • 做网站美工未来规划wordpress fold主题
  • 网站域名备案查询wordpress生成接口
  • 高端品牌网站建设(杭州)北京网站优化实战
  • 手机网站建设可行性分析江苏品牌网站建设
  • 注册外贸网站有哪些哪个网站可以做淘宝代码
  • 网站界面设计简单公司网站建设前期情况说明
  • 昆山网站建设 熊掌号免费创建社区论坛网站
  • 免费的软件下载网站宁乡网页设计
  • 宝山宜昌网站建设百度推广没有效果怎么办
  • 网站建设的报告分析工信部查网站备案
  • 网站个人空间郑州哪家专业做淘宝网站
  • 网站运行团队建设做竞价要会做网站吗
  • 网站建设swf播放器源码阳江招聘网最新招聘信息网官网
  • 时尚工作室网站源码个人业务网站免费制作
  • 工业和信息化部网站备案系统酒店类网站开发策略
  • 炫酷网站首页拼多多网站建设过程
  • 网站建设用的软件阜创汇网站建设名额
  • 大连网站制作杭州网站定制开发