MaximoAccess

Caro Usuário, antes de postar pela primeira vez, leia as regras do fórum.

https://www.maximoaccess.com/t48-regras-do-forum

Obrigado

Administração


Participe do fórum, é rápido e fácil

MaximoAccess

Caro Usuário, antes de postar pela primeira vez, leia as regras do fórum.

https://www.maximoaccess.com/t48-regras-do-forum

Obrigado

Administração

MaximoAccess

Gostaria de reagir a esta mensagem? Crie uma conta em poucos cliques ou inicie sessão para continuar.

Dicas Ms Access, Exemplos Ms Access, Codigos VBA Ms Access, SQL Ms Access


3 participantes

    [Resolvido]Copiar arquivos via Access e renomear

    avatar
    MMS
    Intermediário
    Intermediário


    Respeito às regras : Respeito às Regras 100%

    Sexo : Masculino
    Localização : Brasil
    Mensagens : 112
    Registrado : 12/04/2011

    [Resolvido]Copiar arquivos via Access e renomear Empty [Resolvido]Copiar arquivos via Access e renomear

    Mensagem  MMS 25/11/2017, 20:46

    Peguei alguns exemplos aqui no Fórum de como copiar, mover arquivos de uma pasta para outra via Access e adaptei para minha necessidade. Está quase tudo perfeito, ocorre que preciso copiar um arquivo da pasta de origem e depois renomea-lo na pasta de Destino, Exemplo tem um arquivo FotoLoja.Jpg (origem) e preciso Renomear para FotoLoja_1.Jpg (Destino).

    Alguém sabe como posso fazer isso? abaixo segue o código como está hoje funcionando, porém sem renomear, apenas copiando.


    On Error GoTo MostraErro

    Dim fso, Item
    Dim strOrigem As String, strDestino As String

    If ListaFicheiros.ItemsSelected.Count = 0 Then
    MsgBox "Não tem nenhum arquivo selecionado.", 64, "Marcelo"

    Exit Sub
    End If
    strOrigem = Me.TopDir
    LePasta: strDestino = "T:\ANEXOS\"
    If strDestino = "" Then
    If MsgBox("Deve escolher uma pasta válida, ou cancelar a operação.", vbOKCancel) = vbYes Then
    GoTo LePasta
    Else
    Exit Sub
    End If
    End If
    Set fso = CreateObject("Scripting.FileSystemObject")
    'Se é invalida a pasta de Origem ou Destino
    If Not fso.FolderExists(strOrigem) Then
    MsgBox strOrigem & " Caminho invalido para a pasta de origem.", vbInformation, "Erro"
    ElseIf Not fso.FolderExists(strDestino) Then
    MsgBox strDestino & " Caminho invalido para a pasta de destino", vbInformation, "Erro"
    'Se não há arquivos a serem movidos
    Else
    If Right(strDestino, 1) <> "\" Then strDestino = strDestino & "\"
    For Each Item In ListaFicheiros.ItemsSelected

    'Se quiser copiar
    fso.CopyFile (strOrigem & "\" & ListaFicheiros.Column(0, Item)), strDestino
    Next

    Call Atualise
     
    ListaFicheiros.RowSource = ""


    DoCmd.Close A_FORM, "Selecionar_Arquivos"

    MsgBox strOrigem & " ARQUIVOS TRANSFERIDOS COM SUCESSO.", vbInformation, "Concluído"

    End If
    Exit Sub
    MostraErro:
    MsgBox Err.Number & vbCr & Err.Description
    Avelino Sampaio
    Avelino Sampaio
    Developer
    Developer


    Respeito às regras : Respeito às Regras 100%

    Sexo : Masculino
    Localização : Brasil
    Mensagens : 3900
    Registrado : 04/04/2010

    [Resolvido]Copiar arquivos via Access e renomear Empty Re: [Resolvido]Copiar arquivos via Access e renomear

    Mensagem  Avelino Sampaio 26/11/2017, 06:03

    MMS,

    para renomear, utilize o comando NAME AS do Access. Veja como, neste tópico abaixo:

    nota: copie e cole o endereço no seu navegador.

    redeaccess.com.br/viewtopic.php?f=17&t=1837&p=8059&hilit=Name#p8059

    Sucesso!
    avatar
    MMS
    Intermediário
    Intermediário


    Respeito às regras : Respeito às Regras 100%

    Sexo : Masculino
    Localização : Brasil
    Mensagens : 112
    Registrado : 12/04/2011

    [Resolvido]Copiar arquivos via Access e renomear Empty Copiar arquivos via Access e renomear

    Mensagem  MMS 27/11/2017, 14:55

    Avelino boa tarde!

    Muito obrigado, acrescentei no código a linha em vermelho com sua dica , conforme abaixo e funcionou perfeito! Não sei se tinha como fazer melhor na mesma linha, mas assim como está funcionou.

    'Se quiser copiar
    fso.CopyFile (strOrigem & "\" & ListaFicheiros.Column(0, Item)), strDestino
    Name (strDestino & "\" & ListaFicheiros.Column(0, Item)) As (strDestino & "\" & "MeuId" & "-" & ListaFicheiros.Column(0, Item))

    Next

    avatar
    nelsonprint
    Novato
    Novato


    Respeito às regras : Respeito às Regras 100%

    Sexo : Masculino
    Localização : Brasil
    Mensagens : 15
    Registrado : 18/07/2011

    [Resolvido]Copiar arquivos via Access e renomear Empty Re: [Resolvido]Copiar arquivos via Access e renomear

    Mensagem  nelsonprint 24/2/2019, 21:29

    Olá MMS

    Também to precisando dessa função.
    Vc tem como disponibilizar o md funcionando, visto que ainda estou estudando e tenho conhecimento bem básico de código VB.
    Desde já agradeço.


    Conteúdo patrocinado


    [Resolvido]Copiar arquivos via Access e renomear Empty Re: [Resolvido]Copiar arquivos via Access e renomear

    Mensagem  Conteúdo patrocinado


      Data/hora atual: 7/11/2024, 22:10