Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
RicardoVCM

Como alterar nome da Sheet e do arquivo?

Recommended Posts

Amigos, boa tarde.

 

Não domino completamente o VBA, portanto tive uma dúvida ao criar uma rotina para a minha planilha do Excel.

 

Esse Macro tem a finalidade de criar uma folha de rosto, mantendo as memórias de cálculo da planilha e colando os valores que são pesquisados de algumas bases.

 

Segue o macro que eu fiz: (É bem simples)

Sub Copy_Paste()'' Este macro cria uma cópia da Folha de Rosto do recálculo para um novo documento, mantendo as memórias de cálculo.''    Sheets("Recálculo").Select    Sheets("Recálculo").Copy    ActiveSheet.Unprotect        ActiveSheet.Shapes.Range(Array("Button 1")).Select        ActiveSheet.Shapes.Range(Array("Button 1", "Button 2")).Select            Selection.Delete    Range("A1:K6").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("C8:D22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("G8:G22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("I8:I22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("K8:M22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("O8:S22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("Y8:Y22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("AA8:AA22").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=False    Range("B37:D1994").Select        Selection.Copy            Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _        :=False, Transpose:=FalseEnd Sub

Então, a planilha que eu fiz tem o nome do cliente na célula F3, e eu queria que esse macro renomeasse a Sheet com o nome do cliente (não um nome pré definido) e abrisse aquela Janela de "Salvar como", para que a pessoa escolha o nome que vai salvar o arquivo.

 

Desde já agradeço a ajuda!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá, Ricardo.

Experimente substituir o seu código por este

   

Sub Copy_PasteV2()     Dim r As Range    ' Este macro cria uma cópia da Folha de Rosto do recálculo para um novo _       documento, mantendo as memórias de cálculo.       Sheets("Recálculo").Copy       With ActiveSheet        .Unprotect        .Shapes.Range(Array("Button 1", "Button 2")).Delete         Set r = Union(.[A1:K6], .[C8:D22], .[G8:G22], .[I8:I22], .[K8:M22], .[O8:S22], .[Y8:Y22], _            .[AA8:AA22], .[B37:D1994])         r.Value = r.Value       .Name = [F3]       End With     Application.Dialogs(xlDialogSaveAs).Show    End Sub

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • Autor do tópico
  •  

    Olá, Ricardo.

    Experimente substituir o seu código por este

    Sub Copy_PasteV2()     Dim r As Range    ' Este macro cria uma cópia da Folha de Rosto do recálculo para um novo _       documento, mantendo as memórias de cálculo.       Sheets("Recálculo").Copy       With ActiveSheet        .Unprotect        .Shapes.Range(Array("Button 1", "Button 2")).Delete         Set r = Union(.[A1:K6], .[C8:D22], .[G8:G22], .[I8:I22], .[K8:M22], .[O8:S22], .[Y8:Y22], _            .[AA8:AA22], .[B37:D1994])         r.Value = r.Value       .Name = [F3]       End With     Application.Dialogs(xlDialogSaveAs).Show    End Sub

    Olá Osvaldo, muito obrigado pela sua atenção.

     

    Eu colei esse macro e quando executei, ele deu um erro "400" no Visual Basic e então quando fui conferir o resultado, ele somente criou uma cópia do arquivo, mas manteve as fórmulas matriciais e os Procvs, etc, além de não ter excluído os botões e nem renomeou a tabela.

     

    Acredito que esse erro tenha ocorrido no inicio do código e ele finalizou antes mesmo de entrar na "With".

     

    E outra coisa, é que eu uso o colar especial e o mesmo não pode ser feito para várias seleções, então eu acho que essa parte do "Set r" não vai funcionar, né?

    Editado por RicardoVCM

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Olá, Ricardo.

     

    Postei um código elaborado com base no código que você disponibilizou mas sem uma cópia do seu arquivo não pude testá-lo.

     

    Sugiro que você disponibilize uma amostra do seu arquivo com o código original instalado.

    • Curtir 1

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Crie uma conta ou entre para comentar

    Você precisar ser um membro para fazer um comentário






    Sobre o Clube do Hardware

    No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações sobre tecnologia do Brasil. Leia mais

    Direitos autorais

    Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

    ×