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:  
Igor F.

Formatações e bugs VBA

Recommended Posts

Olá,

sou novato nessa área de programação VBA, e preciso desse "programa" de recibo para facilitar o trabalho aqui na empresa kk

Já ta salvando tudo certinho, a parada é a formatação.

Como por exemplo ao passar do userform (formpesquisa) para sheets(2) (DADOS) e passar com as formatações corretas de destino.

 

 

Queria algumas coisas a serem alteradas: kk

 

1. No userform na parte do recibo fazer a formatação igual da planilha 2 (dados), de 6 para 000006

 

2. Formatação ao digitar do cpf 12365478920 para 123.654.789-20

 

3. Data 17051997 para 17/05/1997

 

4. Se possivel fazer uma caixa de seleção para o emitente, com o nome dos emitentes.

 

5. Se possível² fazer uma atualização automatica quando o recibo for gerado o numero do recibo será atualizado.

 

 

Código do btnincluir:

Private Sub btnincluir_Click()
    
    Sheets(1).Activate
    ' VALOR
    ActiveSheet.Range("J3").Select
    ActiveCell.Value = Me.ctxtvalor
    ' CLIENTE
    ActiveSheet.Range("E6").Select
    ActiveCell.Value = Me.ctxtcliente
    ' CPF
    ActiveSheet.Range("J6").Select
    ActiveCell.Value = Me.ctxtcpf
    ' VEICULO
    ActiveSheet.Range("E11").Select
    ActiveCell.Value = Me.ctxtveiculo
    ' PLACA
    ActiveSheet.Range("J11").Select
    ActiveCell.Value = Me.ctxtplaca
    ' EMITENTE
    ActiveSheet.Range("G15").Select
    ActiveCell.Value = Me.ctxtemitente
    
    linha = Sheets(2).Cells(Rows.Count, 1).End(xlUp).Row + 1
        Sheets(2).Range("A" & linha) = Me.txtcrecibo
        Sheets(2).Range("B" & linha) = Me.ctxtcliente
        Sheets(2).Range("C" & linha) = Me.ctxtcpf
        Sheets(2).Range("D" & linha) = Me.ctxtveiculo
        Sheets(2).Range("E" & linha) = Me.ctxtplaca
        Sheets(2).Range("F" & linha) = Me.ctxtvalor
        Sheets(2).Range("G" & linha) = Me.ctxtemitente
        Sheets(2).Range("H" & linha) = Me.ctxtdata
    
    MsgBox "Recibo gerado com sucesso!", vbInformation, ""
    P_Range = "A1:L18"
    ActiveSheet.PageSetup.PrintArea = P_Range
    ActiveWindow.SelectedSheets.PrintOut copies:=1, Collate:=True, _
        IgnorePrintAreas:=False

    ctxtvalor.Text = ""
    ctxtcliente.Text = ""
    ctxtcpf.Text = ""
    ctxtveiculo.Text = ""
    ctxtplaca.Text = ""
    ctxtemitente.Text = ""

    Me.Hide
End Sub

Comandos ao inicializar:

 

Private Sub UserForm_Initialize()
    Me.txtcliente.Enabled = False
    Me.txtcpf.Enabled = False
    Me.txtdata.Enabled = False
    Me.txtemitente.Enabled = False
    Me.txtvalor.Enabled = False
    Me.txtveiculo.Enabled = False
    Me.txtplaca.Enabled = False
    Me.txtcrecibo.Enabled = False
    Me.ctxtdata.Enabled = False
      
    Sheets(1).Activate
    Me.ctxtdata.Text = Range("G16")
    Me.txtcrecibo.Text = Range("G3")
End Sub

 

Sem título.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá, também sou bem iniciante em VBA e coincidentemente estava vendo exatamente isso hoje.
para formatar da forma que você quer, você pode usar o keypress, que consiste em dizer ao excel onde entrarão os caracteres que deseja, exemplo:
 

Capturar.thumb.PNG.1b6285bce15e087ee23d03dfdd2a543f.PNG

 

No exemplo acima, depois do primeiro caractere entrara um (

 

e assim você vai ajeitando conforme deseja

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

×