如何在JSP / Java中从double中获得全部和分数部分?如果值为3.25,那么我想得到fractional =.25
,whole = 3
我们如何用Java做到这一点?
如何在JSP / Java中从double中获得全部和分数部分?如果值为3.25,那么我想得到fractional =.25
,whole = 3
我们如何用Java做到这一点?
Answers:
http://www.java2s.com/Code/Java/Data-Type/Obtainingtheintegerandfractionalparts.htm
double num;
long iPart;
double fPart;
// Get user input
num = 2.3d;
iPart = (long) num;
fPart = num - iPart;
System.out.println("Integer part = " + iPart);
System.out.println("Fractional part = " + fPart);
输出:
Integer part = 2
Fractional part = 0.2999999999999998
2.3
,但肯定不是2.3
。除非您想要的有效位数超过10个,否则输出没有任何问题。您需要做的是在每个输出中进行四舍五入(例如format %.9f
),通常比减轻痛苦BigDecimal
。唯一的问题是溢出。
(long)1.0e100
您将获得0。很多时候,您需要double值只是简单地“泛滥”了floor()
。如果要同时使用积分和分数部分modf()
。确实,这是一个错误的答案。
double value = 3.25;
double fractionalPart = value % 1;
double integralPart = value - fractionalPart;
%
表示模(-3.25 % 1 == 0.75
),而其他语言(例如Java,Fortran,C和C ++)用于%
表示余数(-3.25 % 1 == -0.25
)。为了方便起见,WindRider可能已将其键入Python REPL中,但该答案具有误导性,因为此问题与JVM有关。
由于这个1岁的问题是由纠正问题主题的人提出的,因此该问题被标记为 jsp,并且这里没有人能够给出以JSP为目标的答案,所以这是我以JSP为目标的贡献。
使用JSTL(只需将jstl-1.2.jar放入/WEB-INF/lib
)fmt taglib中。有一个<fmt:formatNumber>
标签,它可以在maxFractionDigits
和maxIntegerDigits
属性的帮助下以非常容易的方式完全满足您的需求。
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<%
// Just for quick prototyping. Don't do this in real! Use servlet/javabean.
double d = 3.25;
request.setAttribute("d", d);
%>
<!doctype html>
<html lang="en">
<head>
<title>SO question 343584</title>
</head>
<body>
<p>Whole: <fmt:formatNumber value="${d}" maxFractionDigits="0" />
<p>Fraction: <fmt:formatNumber value="${d}" maxIntegerDigits="0" />
</body>
</html>
输出:
整体:3
分数:.25
而已。无需借助原始Java代码来完善它。
最初的问题要求的是指数和尾数,而不是分数和整数部分。
要从双精度中获取指数和尾数,可以将其转换为IEEE 754表示形式,并提取如下位:
long bits = Double.doubleToLongBits(3.25);
boolean isNegative = (bits & 0x8000000000000000L) != 0;
long exponent = (bits & 0x7ff0000000000000L) >> 52;
long mantissa = bits & 0x000fffffffffffffL;
您必须首先找到小数点后的主要数字的主要逻辑。
该代码适用于最多16位数字。如果使用BigDecimal,则最多只能运行18位数字。将输入值(您的数字)放入变量“ num”,此处以示例为例,我对其进行了硬编码。
double num, temp=0;
double frac,j=1;
num=1034.235;
// FOR THE FRACTION PART
do{
j=j*10;
temp= num*j;
}while((temp%10)!=0);
j=j/10;
temp=(int)num;
frac=(num*j)-(temp*j);
System.out.println("Double number= "+num);
System.out.println("Whole part= "+(int)num+" fraction part= "+(int)frac);
IEEE双浮点数的尾数和指数是这样的值:
value = sign * (1 + mantissa) * pow(2, exponent)
如果尾数的形式为0.101010101_base 2(即,其最显着的位移到二进制点之后),并且对指数进行了偏置调整。
从1.6开始,java.lang.Math还提供了一种直接方法来获得无偏指数(称为getExponent(double))。
但是,您要查询的数字是该数字的整数和小数部分,可以使用
integral = Math.floor(x)
fractional = x - Math.floor(x)
尽管您可能希望对负数进行不同的处理(floor(-3.5) == -4.0)
,具体取决于您为何希望这两部分。
我强烈建议您不要称这些尾数和指数。
整数部分来自简单的转换以及分数转换-字符串拆分:
double value = 123.004567890
int integerPart = (int) value; // 123
int fractionPart =
Integer.valueOf(String.valueOf(value)
.split(".")[1]); // 004567890
/**
* To control zeroes omitted from start after parsing.
*/
int decimals =
String.valueOf(value)
.split(".")[1].length(); // 9
如果您的电话号码是2.39999999999999,该怎么办。我想您想获得确切的十进制值。然后使用BigDecimal:
Integer x,y,intPart;
BigDecimal bd,bdInt,bdDec;
bd = new BigDecimal("2.39999999999999");
intPart = bd.intValue();
bdInt = new BigDecimal(intPart);
bdDec = bd.subtract(bdInt);
System.out.println("Number : " + bd);
System.out.println("Whole number part : " + bdInt);
System.out.println("Decimal number part : " + bdDec);
由于fmt:formatNumber
标记并不总是能产生正确的结果,因此这是另一种仅JSP的方法:它只是将数字格式化为字符串,并对字符串进行其余的计算,因为这更容易且不涉及进一步的浮点数算术。
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%
double[] numbers = { 0.0, 3.25, 3.75, 3.5, 2.5, -1.5, -2.5 };
pageContext.setAttribute("numbers", numbers);
%>
<html>
<body>
<ul>
<c:forEach var="n" items="${numbers}">
<li>${n} = ${fn:substringBefore(n, ".")} + ${n - fn:substringBefore(n, ".")}</li>
</c:forEach>
</ul>
</body>
</html>
fmt:formatNumber
四舍五入它的参数,在这种情况下是不需要的。
对于-0到-1.0之间的负数,可接受的答案不能很好地工作。还应将小数部分设为负数。
例如:对于数字-0,35
退货
整数部分= 0小数部分= -0.35
如果您正在使用GPS坐标,则最好在整数部分上使用符号表示结果:
整数部分= -0小数部分= 0.35
这些数字例如用于GPS坐标,这对于纬度或经度位置的信号很重要
提出代码:
double num;
double iPart;
double fPart;
// Get user input
num = -0.35d;
iPart = (long) num;
//Correct numbers between -0.0 and -1.0
iPart = (num<=-0.0000001 && num>-1.0)? -iPart : iPart ;
fPart = Math.abs(num - iPart);
System.out.println(String.format("Integer part = %01.0f",iPart));
System.out.println(String.format("Fractional part = %01.04f",fPart));
输出:
Integer part = -0
Fractional part = 0,3500
从Java 8开始,您可以使用Math.floorDiv
。
它返回int
小于或等于代数商的最大(最接近正无穷大)值。
一些例子:
floorDiv(4, 3) == 1
floorDiv(-4, 3) == -2
或者,/
可以使用运算符:
(4 / 3) == 1
(-4 / 3) == -1
参考文献:
String value = "3.06";
if(!value.isEmpty()){
if(value.contains(".")){
String block = value.substring(0,value.indexOf("."));
System.out.println(block);
}else{
System.out.println(value);
}
}
// target float point number
double d = 3.025;
// transfer the number to string
DecimalFormat df = new DecimalFormat();
df.setDecimalSeparatorAlwaysShown(false);
String format = df.format(d);
// split the number into two fragments
int dotIndex = format.indexOf(".");
int iPart = Integer.parseInt(format.substring(0, dotIndex)); // output: 3
double fPart = Double.parseDouble(format.substring(dotIndex)); // output: 0.025
好的,这可能已经晚了,但是我认为最好,更准确的方法是使用BigDecimal
double d = 11.38;
BigDecimal bigD = BigDecimal.valueOf(d);
int intPart = bigD.intValue();
double fractionalPart = bigD.subtract(BigDecimal.valueOf(intPart)).doubleValue();
System.out.println(intPart); // 11
System.out.println(fractionalPart ); //0.38
input (5.03)
output int = 5 , fractional = 0.0299999
,我们在谈论输入和输出,您投入价值并取回您的价值而不会损失0.001%!而且此准确无误导!