VB.NET程序目录下写日志

System.Environment.CurrentDirectoryApplication.StartupPath获取程序启动路径的区别:
System.Environment.CurrentDirectory的含义是获取或设置当前工作路径,而Application.StartupPath是获取程序启动路径,表面上看二者没什么区别,但实际上区别大得很。

先说前者:比如说你程序放在桌面上启动,但是中间你用了一个OpenFileDialog打开了E盘名为abc的文件夹下的某一个文件,那么CurrentDirectory就变成E:\abc了,所以如果你想再获取程序启动文件夹的某一个文件就没用了,但是Application.StartupPath就不会这样了,无论你中间打开了哪个盘的文件,启动路径都是在桌面那里,一直不会变。

    ''' <summary>
    ''' 获取根目录
    ''' </summary>
    ''' <returns></returns>
    ''' <remarks></remarks>
    Public Shared Function GetPath() As String
        Return Application.StartupPath
        'Return System.Environment.CurrentDirectory
    End Function

    ''' <summary>
    ''' 写日志
    ''' </summary>
    ''' <param name="strStyle">操作类型</param>
    ''' <param name="strContent">操作内容</param>
    ''' <remarks></remarks>
    Public Shared Sub WriteLog(ByVal strStyle As String,ByVal strContent As String)
        Dim curDate As String = CDate(Now).ToString("yyyy-MM-dd HH:mm:ss")
        Dim path As String = GetPath() & "\log"
        If Not My.Computer.FileSystem.DirectoryExists(path) Then
            My.Computer.FileSystem.CreateDirectory(path)
        End If
        path &= "\" & CDate(curDate).ToString("yyyyMMdd") & ".txt"
        If Not My.Computer.FileSystem.FileExists(path) Then
            My.Computer.FileSystem.WriteallText(path,String.Empty,False)
        End If

        Dim strValue As String = String.Empty
        strValue = "******************" & curDate & "**********************" & vbCrLf
        strValue &= "*************操作类型[" & strStyle & "]***************" & vbCrLf
        strValue &= "***************错误原因***************" & vbCrLf
        strValue &= strContent & vbCrLf & vbCrLf & vbCrLf
        My.Computer.FileSystem.WriteallText(path,strValue,True)
    End Sub

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...