Having read a number of questions/answers over the past few weeks, I have seen the use of
$find /System/Library/Perl/5.8.8/ -name \*pm | xargs grep '\\d' | wc -l
$find /System/Library/Perl/5.8.8/ -name \*pm | xargs grep '\[0-9\]' | wc -l
For maximum safety, I'd suggest using
[0-9] any time you don't specifically intend to match all unicode-defined digits.
Per perldoc perluniintro, Perl does not support using digits other than
[0-9] as numbers, so I would definitely use
[0-9] if the following are both true:
You want to use the result as a number (such as performing mathematical operations on it or storing it somewhere that only accepts proper numbers (e.g. an INT column in a database)).
It is possible non-digits
[^0-9] would be present in the data in such a way that the regular expression could match them. (Note that this one should always be considered true for untrusted/hostile input.)
If either of these are false, there will only rarely be reason to specifically not use
\d (and you'll probably be able to tell when that is the case), and if you're trying to match all unicode-defined digits, you'll definitely want to use