![]() |
|
Forum
|
|
|
#1 (permalink) |
|
XLDnaute Occasionel
|
Bonjour le Forum,
Je ne sais pas si j'ai choisi le bon Forum(Excel ou le Salon), mais je voulais vous proposer de tester mon Appli avant de la soumettre. Déjà, cela est-il possible ? Si oui, comment faire ? J'en ai fait un Autoextractible, pour qu'il soit dézippé dans au bon endroit, pour un bon fonctionnement. Et en plus, il fait 5.27Mo :whistle: . On est loin des 50Ko... :lol: J'ai juste un petit problème... Certaine fois, à la fermeture, il me plante Excel97. Oui, je sais . J'entends déjà _Thierry (et d'autre du même avis) qui doit grogner. Mais tant que Microsoft ne proposera pas des Mise à jour à moindre prix, comme beaucoup d'autre le font, plutôt que racheter une version complète à prix ...Enfin, le propos n'était pas là... Merci de vos réponses. EDITION : Les modif proposées par Pascal, Hervé et Jam sont mis en place Retrouvez mon fichier ici Message édité par: laurent45, à: 24/11/2005 10:23 |
|
|
|
| ANNONCES | |||
|
|
|
|
#2 (permalink) |
|
XLDnaute Barbatruc
Date d'inscription: février 2005
Localisation: Saint-Etienne
Version Excel : Excel XP (PC)
Messages: 4 450
|
Bonsoir laurent
Je n'arrive pas à installer ton fichier (archive endommagée). Sinon j'avais téléchargé la premiere version. A l'installation, ton appli s'installait dans c:\\casisses, créant un bug avec le chdir de l'évenementielle open. A la fermeture, je ne retrouve plus mes barres d'etat, formules, ascenseur, listes des onglets, et je perd la barre d'outils visual basic. Sinon, je trouve ton application très bien faite, très soigné, avec en plus une aide conséquente. en espérant t'avoir aidé, car tel etait le but de mon intervention. salut |
|
|
|
|
|
#3 (permalink) |
|
Super Moderator
Date d'inscription: février 2005
Localisation: Rennes
Version Excel : Excel 2000 (PC)
Messages: 8 226
|
Bonjour
Moi personnellement contrairement au clone d'Hervé B) tout s'est bien passé a l'install Bon j'aime pas trop les barres qu'on enlève mais bon tu laisses la principale au cas où Sinon ton UF s'est bien ouvert mais je n'ai pas tester le remplissage j'ai plus rien en caisse que veux-tu :unsure: Sinon côté design moi j'aime bien Bonne soirée
__________________
Pascal(Visitez mon Blog Photo)Vous pouvez devenir "Supporter XLD", plus de renseignements ICI |
|
|
|
|
|
#4 (permalink) |
|
XLDnaute Occasionel
|
Bonjour Hervé, Pascal, le Forum,
Désolé Hervé , j'ai tendance à vouloir aller trop vite :S C'est la passion J'ai fait le test comme toi, et j'ai donc réparé mon erreur :ermm: :whistle: Merci de vos appréciation. Ce fichier peut-il être transmis sur le Site ? Pensez-vous que ça puisse intéresser le XLDennes et les XLDiens ? @+ |
|
|
|
|
|
#5 (permalink) |
|
XLDnaute Impliqué
|
Salut Laurent, Pascal, Hervé,
Bon j'ai regardé et testé (partiellement) ton appli et voici mes quelques petites remarques: - Install: Si tu pouvais laisser le choix de l'emplacement aux utilisateurs ce sera parfait (moins il y a de chose à la racine de C: et mieux c'est en général). Pour cela tu peux utiliser Thisworkbook.Path afin d'obtenir le chemin de ton fichier XL et gérer le reste à partir de là. Bravo pour l'utilisation d'un installeur (l'initiative est assez rare pour être soulignée). Bien joué. - Les barres d'outils: je partage l'avis de Pascal concernant la 'disparition' momentanée des barres d'outils. Même si ce n'est pas très grave, il arrive souvent que des utilisateurs crée une multitude de barre, et il faudrait 1: que tu les retires toutes, 2: si on bascule vers une autre feuille les rétablir Et comme l'a souligné Hervé en cas de plantage tu met le bazar dans un truc qui rend souvent nerveux l'utilisateur...et il risque de pas aimé ton appli à cause de ce détail ![]() - Le démarrage est assez lent: En fait j'ai remarqué que tu jouais beaucoup avec la sélection des cellules...c'est lent en général. Essaie d'utiliser des noms de cellules pour accéder directement à la ligne ou carrément via un fichier INI. De même tu pourrais avant toute chose dans Workbook_Open mettre Code:
With Application
.ScreenUpdating = False
.Calculation = xlCalculationManual
End With
- Concernant: la gestion des objets dans tes pages...please, nomme-les et utilises des boucles pour assigner leur valeur. Ton code y gagnera en lisibilité et en rapidité. - Les variables: Tu as de nombreuses variables non utilisées dans ton code (cf fichier joint). Supprime les ou à défaut REM-les. De même tu as de nombreuses variables en Variant (beurk, beurk). Evite si possible d'utiliser ce type. C'est consommateur de mémoire et ça pénalise la vitesse. - J'ai remarqué (je ne sais pas si c'est forcément justifié) qu'il y avait beaucoup de répétitions de code...en générale cela signifie qu'il doit y avoir un moyen de transférer cela dans une procédure à part (les événements AfterUpdate dans le userform Accueil). - Remarque générale: La cosmétique c'est super dans un programme et c'est aussi important. Cependant elle ne doit intervenir qu'en fin de développement une fois qu'on est sur (on l'est jamais vraiment hein :lol: ) que le code est au point. (Ex. j'ai pas la zoulie icone qui apparaît dans XL). Bon, à part cela, je trouve ton programme très bien présenté avec de bonne idées. L'utilisation des pages est assez chouette (moi qui les ai souvent détestée ). Ton code est assez riche et cela montre le temps que tu y as passé.J'espère que tu ne prendras pas mal ces quelques réflexions. Bon courage pour la suite. [file name=Variables.zip size=667]http://www.excel-downloads.com/components/com_simpleboard/uploaded/files/Variables.zip[/file]
__________________
Toutes les bonnes idées ne sont pas dans la même tête. |
|
|
|
|
|
#6 (permalink) | ||||||||||||
|
XLDnaute Occasionel
|
Bonsoir Jam, le fil, le Forum,
Jam écrit: Citation:
Je vais maintenant répondre aux modifications que tu me propose. Citation:
Citation:
Je n'ai pas due mettre les bon mots clés. :unsure: Citation:
Citation:
C'est uniquement, pour que l'utilisateur ne puisse pas faire de modif sur les autres feuilles (c'était le souhait du demandeur, je peux presque dire client) Citation:
En fait, j'avais commencé par faire un fichier INI, mais j'ai trop galéré avec les INPUT et OUTPUT (ou WRITE). J'ai une Aide (Excel97), qui est plus que limitée sur ce genre de sujet. Pour le ScreenUpdating, il est vrai que j'aurais pu l'utiliser ici, alors qu'il est présent dans le reste du code... Citation:
Si ça concerne les TextBox de la page Chiffre, je trouvais plus simple de les gérer comme ça. Citation:
Citation:
Pour les Variant, il faut que je teste mes tableaux en Double. Citation:
Je n'ai pas encore réessayé avec le Select dans les With proposé par notre Maître _Thierry. Edition: Après réflexion (au fil du post, je réfléchi sur ce que j'ai écris avant), pour les évènements AfterUpdate, c'est pour avoir un séparateur décimal 'Français', plutôt qu'un point. ReEdition: Replace ne fonctionne pas sous Excel97. J'ai refait des essais Citation:
Tu n'as pas l'icône dans Excel ? C'est pas cool !! Vu le nombre de versions que j'en ai créées !! Citation:
Une dernière chose (pour ce soir). J'ai créé un fichier d'aide, mais je n'arrive pas à le faire prendre en compte par mon fichier. Quelqu'un pourraît-il m'éclairer sur ce problème ? Merci Bonne nuit ! ![]() Edition : Toutes mes excuses Didier MDF Message édité par: laurent45, à: 24/11/2005 15:14 |
||||||||||||
|
|
|
|
|
#7 (permalink) |
|
XLDnaute Impliqué
|
Salut Laurent,
1. Concernant le nommage des controles de userform: D'abord une petite précision: contrairement à son grand frère VB, VBA ne gère pas les index des controles (ex.: Textbox(1)). Donc pour contourner ce problème il faut nommer le control ex Textbox1 et ensuite on utilise son nom dans le code (ex.: controls('Textbox1')) Donc quand je te parle de boucle je l'imaginais dans la lecture d'un range et de l'attribution des valeurs aux textbox. Par exemple si tes textbox son nommée de Textbox1 à Textbox10 et que tu les remplis à partir du range('A20') à range('A29'). Plutôt que d'écrire Textbox1=Range('A1') et ce 10 fois, une petite boucle fera beaucoup mieux l'affaire comme par exemple Code:
For i=1 to 10
controls('Textbox' & i).text=Range('A' & i + 19).value
Next
2. Fichier INI C'est pas toujours très pratique à utiliser mais une fois maîtrisé c'est tout bénéf surtout si tu utilises un installeur qui sait écrire dans l'INI. Tu peux aussi utiliser la Registry qui est une tès bonne solution même si elle est rarement utilisée (Excel propose plusieur fonctions intégrées très simples d'utilisation). Normalement ton installeur doit savoir aussi écrire dans la registry ![]() 3. Les barres d'outils: Tu rétablis quand on change de feuille...pas de classeur ![]() Voili voilou. Je reviendrai peut-être à la charge si j'ai un peu de temps. Bon courage Message édité par: jam, à: 24/11/2005 11:43
__________________
Toutes les bonnes idées ne sont pas dans la même tête. |
|
|
|
|
|
#8 (permalink) |
|
XLDnaute Impliqué
|
Laurent,
Juste un petit truc concernant les feuilles. Tu dis vouloir cacher les barres d'outils, etc pour éviter que les utilisateurs aillent dans les feuilles. Y'a une solution toute bête: Met leur statut Visible en xlVeryHidden. Comme cela elles n'appaîtrons pas dans le menu Feuille>Afficher et resterons accessible lecture/écriture par ton code sans problème. A+
__________________
Toutes les bonnes idées ne sont pas dans la même tête. |
|
|
|
|
|
#9 (permalink) |
|
XLDnaute Occasionel
|
Re Jam, le Forum,
Encore merci pour tes tuyaux Jam. Mais pour la propriété xlVeryHidden des feuilles, je ne peux pas. J'ai des Select qui font fonctionner une fonction Sort pour la feuille CRT : Erreur !! 'GNAPP!!' :evil: comme dans la Pub. Pour le nommage de cellules, je travaille dessus. @+ |
|
|
|
|
|
#10 (permalink) | ||
|
XLDnaute Impliqué
|
Laurent,
Dans module CRTpage, j'ai 'optimisé' la sub suivante: Citation:
Une question aussi: Peux-tu me dire la différence entre : Citation:
Bon courage, A+
__________________
Toutes les bonnes idées ne sont pas dans la même tête. |
||
|
|
|
|
|
#11 (permalink) |
|
XLDnaute Occasionel
|
Re Jam, le Forum,
[ol][li]Merci pour la Sub Gratos [/li][li]Je me suis posé aussi la question !! Donc => ARCHIVE :side: (poubelle)[/li][/ol] On continue : Pour faire des boucles de remplissage des TextBox, il faudrait que je les renomme toutes ! (si j'ai bien compris ce que tu me proposais). Et ensuite, nommer les groupes de cellules concernés, et faire des boucles pour remplir. C'est bien ça ? Par contre, dans une plage nommée, dans quel sens sont lues les cellules. Par lignes ou par colonnes ? Ma logique voudrait que ce soit par ligne, mais je voudrais une confirmation. Merci @+ |
|
|
|
|
|
#12 (permalink) | |
|
XLDnaute Impliqué
|
Laurent,
Encore une petite proposition (attention je ne l'ai pas testé) pour remplacer dans le module ESPECESpage la sub InitializeESP(): - Elle montre l'histoire des boucles + le bon usage des with...end with Citation:
__________________
Toutes les bonnes idées ne sont pas dans la même tête. |
|
|
|
|
|
|
#14 (permalink) |
|
XLDnaute Impliqué
|
Laurent,
Tout à fait d'accord pour le byte un peu moins pour le variant (bon, là il s'agit plus d'une mesure de prudence...si un long ou un double vient à se glisser dans ton range il va falloir rajouter la gestion des erreurs ![]() Continue, je vois que cela rentre :woohoo: :woohoo: :woohoo:
__________________
Toutes les bonnes idées ne sont pas dans la même tête. |
|
|
|
| ANNONCES | |
![]() |
| Liens sociaux |
| Outils de la discussion | |
|
|