Mercurial > ~darius > hgwebdir.cgi > pyinst
comparison misc.py @ 78:47da95b31dcb
Move sifmt function to where it can be reused.
author | Daniel O'Connor <doconnor@gsoft.com.au> |
---|---|
date | Fri, 27 Sep 2024 16:50:42 +0930 |
parents | |
children | 4cc3d0706dd1 |
comparison
equal
deleted
inserted
replaced
77:23c96322cfb6 | 78:47da95b31dcb |
---|---|
1 #!/usr/bin/env python | |
2 | |
3 # Copyright (c) 2024 | |
4 # Daniel O'Connor <darius@dons.net.au>. All rights reserved. | |
5 # | |
6 # Redistribution and use in source and binary forms, with or without | |
7 # modification, are permitted provided that the following conditions | |
8 # are met: | |
9 # 1. Redistributions of source code must retain the above copyright | |
10 # notice, this list of conditions and the following disclaimer. | |
11 # 2. Redistributions in binary form must reproduce the above copyright | |
12 # notice, this list of conditions and the following disclaimer in the | |
13 # documentation and/or other materials provided with the distribution. | |
14 # | |
15 # THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND | |
16 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
17 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
18 # ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE | |
19 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
20 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
21 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
22 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | |
23 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | |
24 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |
25 # SUCH DAMAGE. | |
26 # | |
27 | |
28 def sifmt(_v, dp = 3, unit = 'Hz', sp = ' '): | |
29 '''Format a number using SI prefixes''' | |
30 si_prefixes = ('T', 'G', 'M', 'k', '', 'm', 'ยต', 'n', 'p') | |
31 scale = 10 ** 12 | |
32 v = abs(_v) | |
33 if v == 0: | |
34 sip = "" | |
35 scale = 0 | |
36 for i, sip in enumerate(si_prefixes): | |
37 if v >= scale: | |
38 break | |
39 scale /= 1e3 | |
40 return ('%.' + str(dp) + 'f%s%s%s') % (_v / scale, sp, si_prefixes[i], unit) |