我疯了,我无法找到正确的解决方案:(
我该如何解决这些问题。我有一个循环,我可以得到不同的类型,如:
empty string
10
10K
2.3K
2.34K
2M
2.2M
2.23M
我需要将它们更改为数字:
0
10
10000
2300
2340
2000000
2200000
2230000
答案 0 :(得分:2)
您的步骤应该是:
这可以通过以下方式实现:
def convert(value):
if value:
# determine multiplier
multiplier = 1
if value.endswith('K'):
multiplier = 1000
value = value[0:len(value)-1] # strip multiplier character
elif value.endswith('M'):
multiplier = 1000000
value = value[0:len(value)-1] # strip multiplier character
# convert value to float, multiply, then convert the result to int
return int(float(value) * multiplier)
else:
return 0
values = [
'',
'10',
'10K',
'2.3K',
'2.34K',
'2M',
'2.2M',
'2.23M',
]
# use a list comprehension to call the function on all values
numbers = [convert(value) for value in values]
print numbers
这应该返回
[0, 10, 10000, 2300, 2340, 2000000, 2200000, 2230000]
答案 1 :(得分:2)
快速破解浮标:
In [15]: powers = {'K': 10 ** 3, 'M': 10 ** 6}
In [16]: def f(s):
...: try:
...: if s[-1] in powers.keys():
...: return float(s[:-1]) * powers[s[-1]]
...: else:
...: return float(s)
...: except:
...: return s
...:
In [17]: map(f, ['', '10', '10K', '2.3K', '2.34K', '2M', '2.2M', '2.23M'])
Out[17]: ['', 10.0, 10000.0, 2300.0, 2340.0, 2000000.0, 2200000.0, 2230000.0]
答案 2 :(得分:0)
我同意其他答案,这个解决方案最好在没有正则表达式的情况下解决。
但是,如果您仍然想使用正则表达式,这是使用JavaScript执行此操作的好方法(抱歉,不熟悉Python):
var new_arr = ['','10','10K','2.3K','2.34K','2M','2.2M','2.23M'].map(function(value) {
return value.replace(/^(\d*(?:\.\d+)?)([kgm]?)$/i, function(_, number, group) {
return !group && (number||'0') || parseFloat(number) * Math.pow(10, {'k':3,'m':6,'g':9}[group.toLowerCase()]);
});
});
如果有人可以将它翻译成Python,那将是最好的(它会教我一点Python)。 :))