\define zeropad-range(n:10)<$list filter="[range[1,$n$]]" variable=x ><$reveal type="lteq" default=<<x>> text="9" ><$text text= {{{[<x>addprefix[00]]}}} /></$reveal><$reveal type="gt" default=<<x>> text="9" ><$text text= {{{[<x>addprefix[0]]}}} /></$reveal></$list>\end
\define zeropad-range4(n:10)<$list filter="[range[1,$n$]]" variable=x ><$reveal type="lteq" default=<<x>> text="9" ><$text text= {{{[<x>addprefix[000]]}}} /></$reveal><$reveal type="gt" default=<<x>> text="9" ><$reveal type="lt" default=<<x>> text="99" ><$text text= {{{[<x>addprefix[00]]}}} /></$reveal></$reveal><$reveal type="gt" default=<<x>> text="99" ><$text text= {{{[<x>addprefix[0]]}}} /></$reveal></$list>\end
Ref:
To produce numbers zero padded like001 002 003 ... 099 100Here is a macro to do that
\define zeropad-range(n:10)<$list filter="[range[1,$n$]]" variable=x ><$reveal type="lteq" default=<<x>> text="9" ><$text text= {{{[<x>addprefix[00]]}}} /></$reveal><$reveal type="gt" default=<<x>> text="9" ><$text text= {{{[<x>addprefix[0]]}}} /></$reveal></$list>\end
The below macro works up to 1000
\define zeropad-range4(n:10)<$list filter="[range[1,$n$]]" variable=x ><$reveal type="lteq" default=<<x>> text="9" ><$text text= {{{[<x>addprefix[000]]}}} /></$reveal><$reveal type="gt" default=<<x>> text="9" ><$reveal type="lt" default=<<x>> text="99" ><$text text= {{{[<x>addprefix[00]]}}} /></$reveal></$reveal><$reveal type="gt" default=<<x>> text="99" ><$text text= {{{[<x>addprefix[0]]}}} /></$reveal></$list>\end
[range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,999]]
{{{ [range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,999]] }}}
But we do not know in advance what is the number, and it is given by user!So if n is a variable, then how we can generate these numbers?
[range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,256]]
[range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,999] +[limit<max>]
[range[9]addprefix[00]] [range[10,99]addprefix[0]] [range[100,999] +[limit{$:/temp/input/userlimit}]
\define padder-reg() ^$(len)$$
\define padder(str,len,chr:"0")
<$vars len=<<__len__>>>
<$list filter="[<__str__>addprefix<__chr__>]" variable="padstr">
<$list filter="[<padstr>length[]!regexp<padder-reg>]" emptyMessage=<<padstr>>>
<$macrocall $name="padder" str=<<padstr>> len=<<__len__>> chr=<<__chr__>>/>
</$list>
</$list>
</$vars>
\end
<<padder "25" "15">>
<$vars number="256" length="5">
{{{ [<number>addprefix[000000]split[]last<length>join[]] }}}
</$vars>
That's very clever. Splitting on "nothing". And apparently, somewhat surprisingly, the resulting array doesn't collapse like it frequently does in filters.
It would be nice to have some sort of substring operator to be able to do this without the gymnastics. On the other hand, a padding operator or even a number formatting operator would also be nice, but I think Jeremy has already commented on keeping the list of mathematics/string operators to a minimum.
--Mal
You received this message because you are subscribed to the Google Groups "TiddlyWiki" group.
To unsubscribe from this group and stop receiving emails from it, send an email to tiddlywiki+...@googlegroups.com.
To post to this group, send email to tiddl...@googlegroups.com.
Visit this group at https://groups.google.com/group/tiddlywiki.
To view this discussion on the web visit https://groups.google.com/d/msgid/tiddlywiki/674bd29e-6e4d-4087-bb9e-8481ce85a1a8%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.
<$list filter="[range[.00001,.00100,.00001]removeprefix[0.]]">
</$list>
\define mac(n)
<$list filter="[range[.0001,.1,.0001]removeprefix[0.]limit[$n$]]">
<<currentTiddler>>
</$list>
\end
<<mac 5>>
0001 0002 0003 0004 0005
<<mac 200>>
0001 0002 0003 0004 0005 0006 0007 0008 0009 0010 0011 0012 0013 00140015 0016 0017 0018 0019 0020 0021 0022 0023 0024 0025 0026 0027 00280029 0030 0031 0032 0033 0034 0035 0036 0037 0038 0039 0040 0041 00420043 0044 0045 0046 0047 0048 0049 0050 0051 0052 0053 0054 0055 00560057 0058 0059 0060 0061 0062 0063 0064 0065 0066 0067 0068 0069 00700071 0072 0073 0074 0075 0076 0077 0078 0079 0080 0081 0082 0083 00840085 0086 0087 0088 0089 0090 0091 0092 0093 0094 0095 0096 0097 00980099 0100 0101 0102 0103 0104 0105 0106 0107 0108 0109 0110 0111 01120113 0114 0115 0116 0117 0118 0119 0120 0121 0122 0123 0124 0125 01260127 0128 0129 0130 0131 0132 0133 0134 0135 0136 0137 0138 0139 01400141 0142 0143 0144 0145 0146 0147 0148 0149 0150 0151 0152 0153 01540155 0156 0157 0158 0159 0160 0161 0162 0163 0164 0165 0166 0167 01680169 0170 0171 0172 0173 0174 0175 0176 0177 0178 0179 0180 0181 01820183 0184 0185 0186 0187 0188 0189 0190 0191 0192 0193 0194 0195 01960197 0198 0199 0200
I've no objection to adding a padding operator. I think we should support padding with any character, not just zeros, and somehow should support both left and right padding.