Love the differences, my take on yours ...
> No Multiple single lines with colons.
Agreed.
> No end of line comments.
I use end of line comments when they say something about the actual line - e.g. the units of calculation - if I think it avoids confusion (especially when using a built-in function that isn't named as well as it might be). In languages that allow it, I will actually put this comment in the middle of the code.
> No If statements on a single line.
Agreed, but I do sometimes break this rule, when I feel it helps the readability of the whole block of code.
> All Booleans to say If Boolean = True/False Then rather than If Boolean Then.
Nope. Always makes me wonder whether the variable is inadequately named. And if I want to test for a False, I will use the "Not" construct.
> All groups of comment lines preceded by a space line.
Agreed, and followed by a space line too.
> Comment line directly followed by the code they comment.
If you mean "no space line", then don't agree.
> All dims together
No. In fact, I Dim then colon then assignment statement on the one line, where possible. Or Dim as late as possible.
This comes from using languages that allow (recommend) declaration of variables on the line of initial use and take their scope from the code block indent level they're declared at.
> Indent of two spaces
Agreed. 4 is far too big. Also, tabs converted to spaces.
> Use continuations a lot to try and keep all of the code visible in the standard VBE code window.
Don't agree. I only continue if I think it adds to the readability of the block of code it's in. Otherwise, I go for the readability of the whole block, rather than the readability of individual lines. (I.e. as many lines as possible on the screen, even if I need to scroll to see the remainder of the line.)
> Comments directly below the procedure declaration
Yes, I tend to do this (with a space line top and bottom) but I don't comment procedure declarations much anyway. (1) I make the procedure name self-explanatory if possible. (2) I keep procedures small (aka single-purpose) and have lots of them. (3) In Excel, I put the code in the sheet modules as much as possible and use classes when they're useful, which means that the procedure names are associated with the sheet involved, and thereby obvious to what they're working on.
My different approach is doubtless associated with the fact that OO languages (Java, C++, Ada, etc) account for at least 95% of programming I do.
One very strict rule I impose on myself and anyone working with me is that the style used must be consistent through a whole module. Either new code must be added in the existing style of the module, or the style of the whole module must be changed. (I don't feel a need for different modules to be in the same style, though.)
Regards, Dave S
----- Original Message -----Sent: Wednesday, April 15, 2015 9:44 PMSubject: Re: [ExcelVBA] Auto-populate a cell based on several other values> Styles vary so much.Oooh boy!! Or in my case... girl!> "g" when a global variable is defined in a separate "globals" moduleAt least you have some sort of naming convention.. minimalist though it is! :-)IMHO ... Wormy or not and even if it has been discussed torn apart and put together dissected zillions of times it still bears looking at.
FOr example... just to put the the cat out there... Arguably the greatest coding innovation ever has been indentation!My personal preferred format is....
No Comments before the procedure declaration line
Comments directly below the procedure declaration
Space Line
Dims
Space Line
Code
A comment line of stars
End of procedure line
With...
No Multiple single lines with colons.
No end of line comments.
No If statements on a single line.
All Booleans to say If Boolean = True/False Then rather than If Boolean Then.
All groups of comment lines preceded by a space line.
Comment line directly followed by the code they comment.
All dims together
Indent of two spaces
Use continuations a lot to try and keep all of the code visible in the standard VBE code window.LIsa
To: ExcelVBA <ExcelVBA@yahoogroups.com>
Sent: Mon, Apr 13, 2015 5:25 am
Subject: Re: [ExcelVBA] Auto-populate a cell based on several other values
Oops - I've probably opened a can of worms. :-) My thinking was around coding techniques, rather than styles.Coding style discussions are fun, of course. Styles vary so much. For instance, you use prefixes (sub, fnc, lng, etc) - I never do (except for a "g" when a global variable is defined in a separate "globals" module).
Regards, Dave S
----- Original Message -----Sent: Monday, April 13, 2015 5:13 AMSubject: Re: [ExcelVBA] Auto-populate a cell based on several other values> post the code and ask for coding style suggestionsActually a great idea!!!Everyone has different styles so this would be a terrific "excersize" for the group to chip in!Example.... I use a naming convention for entities of my own which is...Sub procedures always preceeded bur lowercase "sub" and starting with a capital after that.ex... subInitialize()Function procedures likewise but with "fnc" instead of sub.I include a type and a scope in variable prefixes....Dim lnglN as Long... lng = long l = local.The single letter l can be p=parameter m=module level g=globalI also format my code in a particular manner. If people are interested I'd be happy to share.Any other offers?? Anyone use a personal set of "rules"? What are they?I'd also be very interested to know how adding comments solved your probbie Duncan?Lisa
-----Original Message-----
From: 'David Smart' smartware.consulting@gmail.com [ExcelVBA] <ExcelVBA@yahoogroups.com>
To: ExcelVBA <ExcelVBA@yahoogroups.com>
Sent: Sat, Apr 11, 2015 1:37 am
Subject: Re: [ExcelVBA] Auto-populate a cell based on several other values
Glad you got it working.If you'd like "improvement" commentary, by all means post the code and ask for coding style suggestions.
Regards, Dave S
----- Original Message -----Sent: Friday, April 10, 2015 10:54 PMSubject: Re: [ExcelVBA] Auto-populate a cell based on several other valuesGuys, many thanks for the help, tips & pointers.After commenting the code, it became clear what it should have been. I now have it populating as it should!Still looking at it to see if there's anything that can be improved.Once again, cheers.DuncanOn 8 Apr 2015 19:49, "Green 1z@compuserve.com [ExcelVBA]" < ExcelVBA@yahoogroups.com> wrote:
No sorrys ness Duncan... It *seems* like an interesting problem.And don't forget that it's poss to upload a file for the group!LisaNo virus found in this message.
Checked by AVG - www.avg.com
Version: 2015.0.5863 / Virus Database: 4331/9541 - Release Date: 04/15/15
__._,_.___
Posted by: "David Smart" <smartware.consulting@gmail.com>
Reply via web post | • | Reply to sender | • | Reply to group | • | Start a New Topic | • | Messages in this topic (14) |
----------------------------------
Be sure to check out TechTrax Ezine for many, free Excel VBA articles! Go here: http://www.mousetrax.com/techtrax to enter the ezine, then search the ARCHIVES for EXCEL VBA.
----------------------------------
Visit our ExcelVBA group home page for more info and support files:
http://groups.yahoo.com/group/ExcelVBA
----------------------------------
More free tutorials and resources available at:
http://www.mousetrax.com
----------------------------------
Be sure to check out TechTrax Ezine for many, free Excel VBA articles! Go here: http://www.mousetrax.com/techtrax to enter the ezine, then search the ARCHIVES for EXCEL VBA.
----------------------------------
Visit our ExcelVBA group home page for more info and support files:
http://groups.yahoo.com/group/ExcelVBA
----------------------------------
More free tutorials and resources available at:
http://www.mousetrax.com
----------------------------------
.
__,_._,___
Tidak ada komentar:
Posting Komentar