Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

ASTUCES POUR EXCEL.


Information sur la source

Catégorie :VBA Classé sous : Excel, astuce, désactiver, masquer Niveau : Débutant Date de création : 13/12/2008 Date de mise à jour : 11/02/2009 15:09:35 Vu / téléchargé: 8 553 / 1 731

Note :
7,67 / 10 - par 3 personnes
7,67 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (12)
Ajouter un commentaire et/ou une note

Description

Cliquez pour voir la capture en taille normale
Du code simple et classique VBA pour Excel. Des fonctions permettant de masquer au maximum l'application hôte (Excel) et ainsi obliger vos utilisateurs à rester dans les rails de vos projets.
Supprimer les barres d'outils, de titre, la barre d'onglets, désactiver les raccourcis clavier, les combinaisons de touches intempestives, etc...
Donner à votre Macro Excel l'aspect d'une application compilée professionnelle.
 

Source

  • J'ai ajouté quelques tracés géométriques en mode "dynamique" et quelques animations de shape.
J'ai ajouté quelques tracés géométriques en mode "dynamique" et quelques animations de shape.

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
  • astuces_excel.xlsTélécharger ce fichier [Réservé aux membres club]361 472 octets

Télécharger le zip

Historique

13 décembre 2008 19:47:40 :
""
15 décembre 2008 14:21:12 :
Supression d'un bog tout bête du a une modif sur une feuille protégée.
16 décembre 2008 01:49:30 :
Une version tenant compte des observations de BigFish_LeVrai notamment améliorant et simplifiant la désactivation des raccourcis non alphanumériques. Merci encore à BigFish_LeVrai
16 décembre 2008 13:21:16 :
Ici, on limite le danger inhérent à l'utilisation de la fonction "Application.Visible=False" suvant la méthode préconisée par Big_Fish.Le_Vrai
16 décembre 2008 13:22:31 :
Ici, on limite le danger inhérent à l'utilisation de la fonction "Application.Visible=False" suvant la méthode préconisée par Big_Fish.Le_Vrai :(Application.IgnoreRemoteRequests = True)
17 décembre 2008 21:58:34 :
voici la capture d'écran
03 janvier 2009 18:02:32 :
Ajout de quelques tracés géométriques et de quelques animations au niveau des Shapes avec ou sans timer.
11 février 2009 15:09:35 :
oups, je m'aperçois que le bouton "Accès au code" ne fonctionne pas. La chose est corrigée.

Commentaires et avis

signaler à un administrateur
Commentaire de us_30 le 14/12/2008 18:15:48 8/10

Bonjour,

Disons que ce genre de code :
Private Declare Function GetWindowLongA Lib "user32" (ByVal hwnd As Long, ByVal nIndex As Long) As Long

n'est pas vraiment du VB"A", mais du VB.

Amicalement,
Us.

signaler à un administrateur
Commentaire de mimiZanzan le 15/12/2008 02:42:41

Je ne voudrais pas ergoter, mais la fonction dont tu parles, us_30, est tout simplement une fonction API, applicable aussi bien au VB qu'au VBA (entre autres)...
Sinon, le code de piloulac est plutôt sympa et utile à ceux qui ne connaissaient pas encore ces astuces Excel.

signaler à un administrateur
Commentaire de xyface le 15/12/2008 10:06:37

bonjour
je travaille sur une application pour un jeu en ligne: ikariam

je me rejouissait de pouvoir intégrer ce code dans mon travail pour l'ameliorer pour les gars de mon alliance

mais je travaille sous open office et les codes proposés ne fonctionnent sous le calculateur d'open office


y aurait il moyen d'avoir une adaptation du code pour open office?

ou conseils et ou liens


merci d'avance

signaler à un administrateur
Commentaire de us_30 le 15/12/2008 12:34:35

Bonjour,

"applicable aussi bien au VB qu'au VBA"
C'est exactement ce que je dis : "n'est pas vraiment du VB"A", mais du VB." Donc, ce n'est pas spécifiquement du VBA... mais cela n'est pas grande importance, l'intérêt est là. C'était aussi l'occassion de mettre une note... -:);

Amicalement,
Us.

signaler à un administrateur
Commentaire de bigfish_le vrai le 15/12/2008 17:37:24 7/10

Bonjour,

C'est pas mal, cela a au moins le merite de regrouper plusieurs astuces pas toujours faciles a trouver.

Mais...

je ne suis pas d'accord sur la façon de desactiver les combinaisons de touches Alt+F1, Ctrl+PgUp ou Ctrl+PgDn. Il existe une methode qui simplifie le code et fonctionne avec n'importe quelle combinaison de touches. Ce qui est encore plus etrange c'est que tu as utilisé cette methode dans d'autre cas alors pourquoi pas pour ceux-ci ?

Sub DesactiverCombiTouche()
    Application.OnKey "%{F1}", "MessageDeLimitation"
    Application.OnKey "^{PGUP}", "MessageDeLimitation"
    Application.OnKey "^{PGDN}", "MessageDeLimitation"
End Sub
Sub RetablirCombiTouche()
    Application.OnKey "%{F1}"
    Application.OnKey "^{PGUP}"
    Application.OnKey "^{PGDN}"
End Sub
Sub MessageDeLimitation()
    MsgBox "Vos droits sur ce fichier ne vous permettent pas d'acceder à ces fonctions !", vbExclamation
End Sub

Je ne suis pas non plus d'accord avec la methode qui consiste a virer la croix du userform c'est bien compliqué pour pas grand chose. En effet il existe un evenement sur la form qui permet de detecter l'utilisation de la croix et donc de la desactiver.

Private Sub UserForm_QueryClose(Cancel As Integer, CloseMode As Integer)
    If CloseMode = 0 Then Cancel = 1
End Sub

Pour plus d'info sur les limitations que l'on peut appliquer a excel tu peux aller jeter un oeil ici :
http://www.vbfrance.com/codes/AMELIORER-SECURITE-ACCES-DONNEES-CODE-FICHIER-EXCEL_48448.aspx

Autre chose: le fait de rendre invisible excel interdit l'ouverture d'un autre fichier excel c'est dommage pour l'utilisateur ! il existe une solution qui consiste a privatiser la session caché pour obliger excel a créer une autre session si l'utilisateur veut ouvrir un autre fichier par double clic(par exemple):

Sub cacher_Excel()
Application.IgnoreRemoteRequests = True
Application.Visible = False
End Sub
Sub montrer_Excel()
Application.IgnoreRemoteRequests = False
Application.Visible = True
End Sub

A+

signaler à un administrateur
Commentaire de bigfish_le vrai le 15/12/2008 17:57:40

Re,

j'ai pas été tres complet sur la derniere partie donc je precise un peu:

le fait de rendre invisible excel alors que ton userform est encore a l'ecran interdit l'ouverture d'un autre fichier excel c'est dommage pour l'utilisateur et il risque de ne pas comprendre pourquoi! De plus si il ferme le userform et qu'il ouvre un fichier excel cette fois ci excel va reapparaitre et c'est peut etre toi dans ce cas qui va te retrouver dans une situation non souhaitée. Pour eviter ces 2 cas il existe une solution qui consiste a privatiser la session caché pour obliger excel a créer une autre session si l'utilisateur veut ouvrir un autre fichier par double clic(par exemple):


Sub cacher_Excel()
Application.IgnoreRemoteRequests = True
Application.Visible = False
End Sub
Sub montrer_Excel()
Application.IgnoreRemoteRequests = False
Application.Visible = True
End Sub

ceci dit tu as bien geré le cas de la fermeture de la form en remettant l'option visible de l'application a vrai. Cette precision n'est valable que dans le cas d'une appli qui aurait besoin de continuer a tourner meme apres fermeture de la forme et ce sans qu'elle puisse etre rendu visible par l'ouverture d'un autre fichier excel.

A+

signaler à un administrateur
Commentaire de piloulac le 15/12/2008 18:27:25

Merci infiniment à toi BigFish pour tous ces commentaires très judicieux.
J'essaie tout de suite d'intégrer tes conseils à mon petit didacticiel.

signaler à un administrateur
Commentaire de xyface le 16/12/2008 12:40:20

bonjour

cela pourrait fonctionner avec open office 3 et son tableur?

signaler à un administrateur
Commentaire de piloulac le 16/12/2008 12:53:26

XYface, désolé, je ne connais rien à Open Office.
Peut-être un spécialiste pourrait-il te tépondre.

signaler à un administrateur
Commentaire de LUSTRUCRU le 18/12/2008 16:05:49 8/10

Très bien !  astuces très interressantes
petite question :
Comment récuperer (dans une variable) le chemin d'accés d'un fichier Xls à travers une boite de dialogue de type "ouvrir fichier".
merci de vos réponses
et encore merci

signaler à un administrateur
Commentaire de mimiZanzan le 18/12/2008 19:35:53

Très facile:
Dim fichImp
fichImp = Application.GetOpenFilename
Ceci ouvre une boite mais pas le fichier.
Pour l'ouvrir, faire ensuite
Workbooks.Open Filename:=fichImp
C'est tout!

signaler à un administrateur
Commentaire de LUSTRUCRU le 18/12/2008 19:48:57

merci MimiZanzan,
cela fonctionne perfect.
Bonne soirée à tous

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

masquer des lignes sous excel [ par DutPower ] Salut.J'aimerai créer une macro capable de masquer les lignes a zero dans une selection choisie par l'utilisateur.Merci d'avance. désactiver la mise en forme automatique d'Excel [ par tyf ] Bonjour, j'aimerais désactiver la mise en forme automatique d'Excel sur les cellules. Ex: "1-1" devient "01 janvier" J'aimerais trouver un mo masquer excel en gardant vb actif [ par petitmanu ] Bonjour, je voudrais masquer un classeur excel tout en utilisant le programme sous visual basic associé.Merci d'avance pour l'aide Désactiver le touche F1 (Aide Excel) [ par KILIMANJARO ] Bonjour,Quelqu'un peut il me dire comment désactiver la touche F1 de l'aide d'Excel (je la lance souvent par erreur au lieu de la touche F2 et son lan désactiver le bouton maximiser d'une appli excel [ par deck222 ] j'ai créer une appli excel qui ne fonctionne que sous un certain format et j'aimerais donc condamner le bouton aggrandir en haut de la fenêtre excel, Désactiver le curseur d'une page EXCEL [ par doboulan ] DoboulanBonjour à tousJ'ai besoin d'aide pour résoudre un problème dans EXCELJe veux figer une page EXCEL-pas de curseur vertical visible-pas de curse Désactiver les macros (VBA Excel 2000) [ par Zbod ] Salut ! Voilà, j'ai créé une interface en VBA avec Excel 2000 qui ouvre un autre fichier Excel. Jusque là, pas de difficulté ! Le problème est que le Désactiver les macros (VBA Excel 2000) [ par Zbod ] Salut ! Voilà, j'ai créé une interface en VBA avec Excel 2000 qui ouvre un autre fichier Excel. Jusque là, pas de difficulté ! Le problème est que le Affichage Excel sous VB [ par edecoupi ] Bonjour,je voudrais créer un menu sous vb qui afficherait des docts excel. Je souhaite afficher une seule feuille et masquer les autres. Je ne sais pa Masquer des controles [ par Fidoudou ] Bonsoir à tous,J'aurais voulu savoir s'il été possible d'activer et désactiver des controle sur une page ASP.Par exemple je voudrai mettre un champ te


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,452 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.