首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Python想要四舍五入有多麻烦?

大家好,欢迎来到 Crossin的编程教室~ 「四舍五入」是小学就学过的数学知识,也是日常计算中经常会用到的处理方法。...然而让人没想到的是,一个简单的四舍五入操作,在Python居然这么难搞,网上还一堆错误的教程。 来看这个例子,有一个变量a为1.135,现在希望把它保留2位小数,要怎么做?...有些不靠谱的半瓶水教程会跟你说,这是因为Python用了种叫做「四舍六入五成双」的保留机制:5前面的数字是奇数就进位,是偶数就保持不变,所以1.135会得到1.14,而1.125就是1.12。...如果你就是想要按照四舍五入来保留,也可以,通过将 Context 的 rounding 属性设置为 ROUND_HALF_UP 就可以 from decimal import Decimal, ROUND_HALF_UP...不过这里还有一个小小的坑,就是一定要通过字符串去创建 Decimal 对象,否则实际值仍然是带有误差的,从而导致四舍五入失效。 好吧,没想到一个简单的四舍五入操作,竟然还这么复杂,你学会了吗?

13510
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL保存时间时居然四舍五入

    经过排查后发现原来是因为MySQL支持小数秒(一般叫做分秒),但是数据库字段长度不够,导致了四舍五入 问题展示 插入不同大小的小数秒可以看到四舍五入的效果 CREATE TABLE `user_tenmao...(name, birth_time) values('tim2', '2021-06-03T20:26:42.715'); Query OK, 1 row affected (0.01 sec) mysql...----------------+ 1 row in set (0.01 sec) 插入时间是2021-06-03T20:26:42.715,到数据库后进位得到2021-06-03 20:26:43 mysql...(name, birth_time) values('tim2', '2021-06-03T20:26:42.215'); Query OK, 1 row affected (0.01 sec) mysql...rows in set (0.00 sec) 插入时间是2021-06-03T20:26:42.215,到数据库后进位得到2021-06-03 20:26:42 保存小数秒 timestamp(2),后面的数字表示小数秒的位数

    1.5K20

    MySQL面的JSON特性

    即col1面的属性值和col2面的属性值是对应的。或者换句话来说,col1面存放的是key,col2存放的是value....在这种模式下,使用JSON其实也是一种改进思路,当然这是在MySQL 5.7之后了。 我们创建的表为json_test,然后插入两行记录。...jianrong" | "gansu" | +------------+----------------------+ 2 rows in set (0.00 sec) 在这种模式下,上面的第一个难题其实就完全可以使用这种方式来解决了...在这个基础上我们更近一步,在5.7面还有辅助的特性虚拟列和相关的索引,可以提高我们查询的效率。我们添加一个虚拟列user_name....JSON的新特性对于MySQL来说确实是一个不错的特性,如果数据量巨大,还是需要考虑通过空间换时间的思路来改进。

    1.1K00

    MySQL面的在线文档

    作为一款开源产品,MySQL拥有全面的知识文档,这是目前其他开源产品与其无法相比的一点。 本文将向读者介绍MySQL提供的相关文档、内容简介等,帮助读者快速找到所需的知识点。...MySQL的文档包括云指南、MySQL企业版、高可用、复制和可扩展性解决方案、安装、MySQL服务器手册、MySQL集群、MySQL Workbench、MySQL Shell、Router、连接器和API...MySQL企业版监控提供图形化界面的监视软件,包含SLA、复制、性能、查询等全方位的MySQL监视,并支持部署在云中的MySQL。...MySQL Workbench是一款图形化界面的MySQL客户端,用户可以利用其进行SQL开发、建模、管理服务器、数据迁移,及使用企业版相关功能。...以上内容是关于MySQL官网文档的一个简介,文档提供了全面的内容,感兴趣的读者可以详细阅读。 感谢关注“MySQL解决方案工程师”

    2K40

    MySQL之ROUND函数四舍五入的陷阱

    MySQL中,ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误。...field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5); 插入之后表中的数据是这样的 mysql...没办法,还得靠自己,这个时候最有用的就是官网文档了,于是查询了mysql官方文档中关于ROUND函数的部分,其中包含下面两条规则 For exact-value numbers, ROUND() uses...the “round half up” rule(对于精确的数值,ROUND函数使用四舍五入) For approximate-value numbers, the result depends on...总结 从这个例子中可以看到,在MySQL中使用ROUND还是要非常需要注意的,特别是当参与计算的字段中包含浮点数的时候,这个时候计算结果是不准确的。

    79620

    MySQL之ROUND函数四舍五入的陷阱

    [FullSizeRender 2] TOC 在MySQL中,ROUND函数用于对查询结果进行四舍五入,不过最近使用ROUND函数四舍五入时意外发现并没有预期的那样,本文将这一问题记录下来,以免大家跟我一样犯同样的错误...field1, field2, field3, field4, field5, field6) VALUE (100, 100, 100, 1.005, 3.5, 2.5); 插入之后表中的数据是这样的 mysql...没办法,还得靠自己,这个时候最有用的就是官网文档了,于是查询了mysql官方文档中关于ROUND函数的部分,其中包含下面两条规则 For exact-value numbers, ROUND() uses...the “round half up” rule(对于精确的数值,ROUND函数使用四舍五入) For approximate-value numbers, the result depends on...总结 从这个例子中可以看到,在MySQL中使用ROUND还是要非常需要注意的,特别是当参与计算的字段中包含浮点数的时候,这个时候计算结果是不准确的。

    1.7K40

    MySQL对小数进行四舍五入等操作

    数学函数是MySQL中常用的一类函数。其主要用于处理数字,包括整型和浮点数等等。 MySQL常用的四舍五入函数: 函数说明 FLOOR(X) 返回不大于X的最大整数。...ROUND(X) 返回离X最近的整数,截断时要进行四舍五入。 ROUND(X,D) 保留X小数点后D位的值,截断时要进行四舍五入。...TRUNCATE(X,D) 返回数值X保留到小数点后D位的值,截断时不进行四舍五入。 FORMAT(X,D) 将数字X格式化,将X保留到小数点后D位,截断时要进行四舍五入。...SELECT CEIL(1.3); -- 输出结果:2 SELECT CEILING(1.8); -- 输出结果:2 4、ROUND(X)函数 返回离X最近的整数,截断时要进行四舍五入。...SELECT TRUNCATE(1.2328,3); -- 输出结果:1.232 6、FORMAT(X,D)函数 将数字X格式化,将X保留到小数点后D位,截断时要进行四舍五入

    35530

    如何打开win10面的ubuntu系统

    这估计是很多极客弃离windows,选择使用mac或者linux桌面的原因。但mac贵,所以没有钱又不堪windows流氓软件烦扰的穷极客(比如一番)便热衷使用ubuntu桌面系统。...因为大多数朋友使用的都是windows系统,想要使用这个工具只能重新安装ubuntu系统或者在vmware、vbox安装虚拟机来运行程序。...开启“适用于Linux的Windows子系统” 如下图,依次点击:开始(windows)→设置→应用和功能→程序和功能→启用或关闭Windows功能→适用于Linux的Windows子系统,选中前面的选择框既可...开启“开发人员模式” 如下图,依次点击:开始(windows)→设置→更新和安全→开发者选项→开发人员模式,点击前面的单选框即可。 ? 3....在win10运行ubuntu系统 安装成功后便可在开始菜单向打开一个应用一样打开ubuntu的运行环境。我们便有了一个windows下运行ubuntu的环境了。

    7.2K20

    比较全面的MySQL优化参考

    本文整理了一些MySQL的通用优化方法,做个简单的总结分享,旨在帮助那些没有专职MySQL DBA的企业做好基本的优化工作,至于具体的SQL优化,大部分通过加适当的索引即可达到效果,更复杂的就需要具体分析了...版本的选择 官方版本我们称为ORACLE MySQL,这个没什么好说的,相信绝大多数人会选择它。...我个人强烈建议选择Percona分支版本,它是一个相对比较成熟的、优秀的MySQL分支版本,在性能提升、可靠性、管理型方面做了不少改善。...另一个重要的分支版本是MariaDB,说MariaDB是分支版本其实已经不太合适了,因为它的目标是取代ORACLE MySQL。...它主要在原来的MySQL Server层做了大量的源码级改进,也是一个非常可靠的、优秀的分支版本。

    1K40

    Mysql优化方面的面试题

    1、MySQL的复制原理以及流程: 基本原理流程,3个线程以及之间的关联; 1. 主:binlog线程——记录下所有改变了数据库数据的语句,放进master上的binlog中; 2....6、问了下MySQL数据库cpu飙升到500%的话他怎么处理? (1)、没有经验的,可以不问; (2)、有经验的,问他们的处理思路。...在表中找到所需行的方式,又称“访问类型” possible_keys 指出MySQL能使用哪个索引在表中找到行,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询使用 key 显示MySQL...如果能容忍拆分带来的空间问题,拆的话最好和经常要查询的表的主键在物理结构上放置在一起(分区) 顺序IO,减少连接消耗,最后这是一个文本列再加上一个全文索引来尽量抵消连接消耗 如果能容忍不拆分带来的查询性能损失的话:上面的方案在某个极致条件下肯定会出现问题...,那么不拆就是最好的选择 18、MySQL中InnoDB引擎的行锁是通过加在什么上完成(或称实现)的?

    81730

    超全面的 MySQL优化 面试解析

    但是 关键字查询 热搜提醒功能还是可以做的,比如键入mysql之后提醒mysql 教程、mysql 下载、mysql 安装步骤等。...(表层面的管理,不是记录层面的管理,因此失效率较高) 注意事项 应用程序,不应该关心query cache的使用情况。...useradd -r -g mysql mysql cd /export/server chown -R mysql:mysql mysql/ chmod -R 755 mysql/ 创建mysql数据存放目录.../data/mysql/mysql.pid --initialize 如果成功会显示mysql的root账户的初始密码,记下来以备后续登录。...主服务器上面的任何修改都会保存在二进制日志Binary log里面,从服务器上面启动一个I/O thread(实际上就是一个主服务器的客户端进程),连接到主服务器上面请求读取二进制日志,然后把读取到的二进制日志写到本地的一个

    93430
    领券