1
Gracias

Unas palabras de agradecimiento nunca están de más.

VBA/VB6 - Carpeta Mis documentos + Variables de entorno

En el explorador de archivos, la carpeta Mis documentos parece estar en el root pero no es así. Esta carpeta se encuentra en la subcarpeta de C:\Documents and Settings. La cuestión es que la primera subcarpeta toma el nombre del usuario y por lo tanto no solo cambia de un PC a otro, sino que ello también ocurre en un PC multiusuario.




Código

El siguiente código permite visualizar la carpeta Mis documentos independientemente del usuario que esté conectado. Has de ponerlo en un módulo general:

Option Explicit 

Private Type SHITEMID
cb As Long
abID As Byte
End Type
Private Type ITEMIDLIST
mkid As SHITEMID
End Type
Private Const CSIDL_PERSONAL As Long = &H5
Private Declare Function SHGetSpecialFolderLocation Lib "shell32.dll" _
(ByVal hwndOwner As Long, ByVal nFolder As Long, _
pidl As ITEMIDLIST) As Long
Private Declare Function SHGetPathFromIDList Lib "shell32.dll" Alias "SHGetPathFromIDListA" _
(ByVal pidl As Long, ByVal pszPath As String) As Long


Public Function Rep_Documents() As String
Dim lRet As Long, IDL As ITEMIDLIST, sPath As String
lRet = SHGetSpecialFolderLocation(100&, CSIDL_PERSONAL, IDL)
If lRet = 0 Then
sPath = String$(512, Chr$(0))
lRet = SHGetPathFromIDList(ByVal IDL.mkid.cb, ByVal sPath)
Car_Documentos = Left$(sPath, InStr(sPath, Chr$(0)) - 1)
Else
car_Documentos = vbNullString
End If
End Function


Ejemplo de llamado:

Private Sub CommandButton1_Click() 
Cells(5, 2) = Car_Documentos()
End Sub

Mas simple en VB6

En VB6, solo hay que utilizar la variable de entorno UserProfile:

Nota: No funciona en Macintosh pero también funciona en VBA.

Dim sPathUser as String
sPathUser = Environ$("USERPROFILE") & "\mis documentos\"
MsgBox sPathUser

Funciones de entorno

La función Environ$ se utiliza para recibir el valor de una variable de entorno.

Por ejemplo, si tuvieras WINDIR (Windows), obtendrás la carpeta en la que está instalado Windows (por defecto, C:\Windows\).

Estas son variables que puedes utilizar tanto en Batch como en la ventana de diálogo "Ejecutar". Igualmente en un entorno de programación como VB y VBA.

En Windows, presiona la tecla de Windows + R (o menú Inicio > Ejecutar) y escribe %UserProfile%, accederás a la carpeta del usuario actual.

Escribe "%UserProfile%\Mis documentos" para acceder a tus documentos, o escribe %WinDir% para la carpeta de Windows...o %tmp% para las carpetas temporales, etc.

Variables de Windows

Variables de usuario por defecto:
  • TEMP carpeta temporal
  • TMP Carpetas temporales.

Variables de sistema

  • ComSpec ruta de acceso para el intérprete de comandos.
  • FP_NO_HOST_CHECK
  • NUMBER_OF_PROCESSORS
  • OS devuelve el Sistema Operativo que se está utilizando.
  • Path
  • PATHEXT
  • PROCESSOR_ARCHITECTURE devuelve la arquitectura del procesador (x86 etc ...)
  • PROCESSOR_IDENTIFIER devuelve la descripción del procesador.
  • PROCESSOR_LEVEL
  • PROCESSOR_REVISION devuelve el N° de revisión del procesador.
  • TEMP es una carpeta temporal.
  • TMP ídem.
  • windir es la carpeta donde está instalado Windows.
  • SystemRoot ídem.

Anexo

Si eres administrador también puedes cambiar los valores o agregar variables de entorno desde el Panel de control (vista clásica) > Sistema > Configuración avanzada del sistema > Opciones avanzadas > Variables de entorno.

Foto: © Everypixel

1
Gracias

Unas palabras de agradecimiento nunca están de más.

Haz una pregunta
Nuestros contenidos son redactados en colaboración con expertos del ámbito tecnológico bajo la dirección de Jean-François Pillou, fundador de CCM.net. CCM es un sitio de tecnología líder a nivel internacional y está disponible en 11 idiomas.
El documento « VBA/VB6 - Carpeta Mis documentos + Variables de entorno » se encuentra disponible bajo una licencia Creative Commons. Puedes copiarlo o modificarlo libremente. No olvides citar a CCM (es.ccm.net) como tu fuente de información.
1 Comentario

¡Suscríbete a nuestra Newsletter!

Recibe nuestros mejores artículos

¡Suscríbete a nuestra Newsletter!