国产一区国产精品,2019中文亚洲字幕,电影在线高清,欧美精品一区二区三区久久

計量論壇

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
打印 上一主題 下一主題

[數據] GB/T8170數值修約規則在Excel中的實現

[復制鏈接]
跳轉到指定樓層
1#
aux8180 發表于 2012-11-16 17:13:39 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

GB/T8170數值修約規則在Excel中的實現


趙靜儀  林德浩

    利用Excel來進行各種數值的統計分析可以極大的減輕人工計算的工作量和減少人工計算的誤差,但是依據Excel本身的計算規則,所有的數值修約都是按照“四舍五入”來進行的。而在實際工作中,許多數據的運算處理都必須依照GB/T8170-2008《數值修約規則與極限數值的表示和判定》中的數值修約規則進行,在Excel中卻沒有相對應的函數,這樣計算出來的結果就和按GB/T8170-2008的規則修約的結果產生了偏差。
   

一、GB/T8170-2008對數值修約的進舍規則

    GB/T8170-2008的數值修約進舍規則并不是單純的“四舍五入”,而是根據不同情況進行:
    規則一:如果擬舍棄數字的最左一位數字小于5時,則舍去,即保留的各位數字不變。例1:將10.349修約到一位小數,得10.3。
    規則二:如果擬舍棄數字的最左一位數字大于5,則進一,即保留的末位數字加1。例2:將1260修約到百數位,得1300(或13×102)。
    規則三:如果擬舍棄數字的最左一位數字為5,且其后有非0數字時進一,即保留的末位數字加1。例3:將10.501修約到個數位,得11。
    規則四:如果擬舍棄數字的最左一位數字為5,而右面無數字或皆為0時,若所保留的末位數字為奇數(1,3,5,7,9)則進一,為偶數(2,4,6,8,0)則舍棄。
    例4:修約間隔為0.1(或10-1)(見表1)
   


<CTSM>    表1</CTSM>
    規則五:負數修約時,先將它的絕對值按規則一至四進行修約,然后在所得值前面加上負號。
    例5:修約到十數位(見表2)
   


<CTSM>    表2</CTSM>
    規則六:GB/T8170-2008的修約規則中,還有0.5單位修約與0.2單位修約的情況。
    0.5單位修約:將擬修約數值乘以2,然后按指定數位依以上規則一至四進行修約,所得數值再除以2。
    0.2單位修約:將擬修約數值乘以5,然后按指定數位依以上規則一至四進行修約,所得數值再除以5。
   

二、Excel對數值修約的進舍規則

    Excel中的取整函數對數值的修約只有“四舍五入”的規則,當擬舍棄數字的最左一位數字為5,而右面無數字或皆為0時,計算結果就會與GB/T8170-2008修約結果不同。
    例4:修約間隔為0.1(或10-1)(見表3)
   


<CTSM>    表3</CTSM>
   

三、利用自定義函數在Excel中實現GB/T8170-2008修約規則

    Excel的自定義函數是用VBA來編程的,而Visual Basic語言里面的ROUND()函數剛好符合上述的修約規則一至規則五,不過它只能修約小于等于單位1的修約間隔,而且缺少0.5單位和0.2單位的修約間隔,需要做一些補充。下面我們就用VBA來實現新的符合GB/T8170-2008的函數ROUNDGB()。
    第一步:選擇菜單“工具→宏→Visual Basic編輯器”命令(或按下鍵盤Alt+F11組合鍵),打開Visual Basic窗口,我們將在這里自定義函數。
    第二步:進入Visual Basic窗口后,選擇菜單“插入→模塊”命令,于是得到“模塊1”,在其中輸入如下自定義函數的代碼:
    Function ROUNDGB(number1 As Double,Optional digits1 As Integer,Optional flag1 As Double)As Double
    ′本程序實現ROUNDGB()進行GB/T8170-2008數值規則的修約。
    ′參數說明:
    number1擬進行修約的數值(必選參數);
    ′digits1修約的小數位,(可選參數,默認為0,即取整)。大于0,為保留多少位小數;小于0,為保留多少位整數。如digits1=-3表示number1要修約到千數位。
    ′flag1修約間隔(可選參數,默認為1);此參數有0.2,0.5可選,當0.2時表示修約間隔為0.2,當0.5時表示修約間隔為0.5。
    Select Case flag1
    Case 0.5
    number1=number1*2′0.5單位的修約
    Case 0.2
    number1=number1*5′0.2單位的修約
    End Select
    If digits1>=0 Then
    roundgb=Round(number1,digits1)′調用VB的Round函數
    Else
    digits2=-digits1
    roundgb=Round(number1*10^digits1)*10^digits2′當digits1為負數時的處理。
    End If
    Select Case flag1
    Case 0.5
    roundgb=roundgb/2′0.5單位的修約
    Case 0.2
    roundgb=roundgb/5′0.2單位的修約
    End Select
    End Function
    第三步:函數自定義完成后,選擇菜單“文件→關閉并返回到Excel”命令,返回到Excel工作表窗口。這樣我們就可以在Excel里面調用ROUNDGB()函數了。
    表4是Excel取整函數ROUND()和自定義函數ROUNDGB()取值的比較。
   


<CTSM>    表4</CTSM>
   

四、結束語

    Excel本身“四舍五入”的數值修約規則,已經可以滿足大多數日常工作,但在有明確要求使用GB/T8170修約規則的計算、測量、統計中,現有的函數則無法滿足要求。如果單純使用Excel公式的邏輯判斷加數值小數計算來實現本功能,由于Excel本身的局限性,數值計算的準確度不夠,就很容易因為相應誤差而導致出錯。本文使用VBA編程的方式來實現GB/T8170-2008數值修約規則,相對其他方法來說比較容易實現和方便使用,就算是不懂得VB語言的人員,自定義函數一經輸入以后,每次使用時調用ROUNDGB()函數就可以像調用其他Excel函數一樣方便。
    作者單位【廣東省汕頭市質量計量監督檢測所】

2#
pll4681429 發表于 2016-2-18 14:52:37 | 只看該作者
好貼,必須要頂頂
3#
whuisvfg 發表于 2016-3-11 16:38:59 | 只看該作者
不錯的函數,比我以前用過的要簡潔得多。
4#
qlzswk 發表于 2016-3-29 17:11:46 | 只看該作者
謝謝樓主分享啊!!!!
5#
huxh 發表于 2016-4-13 15:55:08 | 只看該作者
謝謝分享。
6#
a492720924 發表于 2016-4-14 13:32:06 | 只看該作者
厲害厲害!
7#
藍波 發表于 2016-4-16 14:38:00 來自手機 | 只看該作者
電腦不太好,學習了
8#
lvjiachen 發表于 2023-9-15 13:24:54 | 只看該作者
學習了,謝謝
9#
wangyiyong7703 發表于 2023-9-15 14:24:13 | 只看該作者
不可能那么簡單,很多特殊情況都沒有考慮。0.10000001,0.999999,修約一下。會出現錯誤。如果不考慮特殊情況,何必用上VB
10#
wangyiyong7703 發表于 2023-9-16 01:01:19 | 只看該作者
A2輸入待修約數字,B2輸入保留小數點位數,C2輸入公式

IF(B2=0,IF(OR(AND(ISEVEN(INT(A2)),A2-INT(A2)=0.5),A2-INT(A2)<0.5),INT(A2),INT(A2)+1),IF(LEN(IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))=LEN(INT(A2)),IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2))&"."&REPT("0",B2),IF(LEN(INT(A2*POWER(10,B2)))+1>LEN((IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))),(IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))&REPT("0",LEN(INT(A2*POWER(10,B2)))-1-LEN((IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2))))),IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))))
11#
wangyiyong7703 發表于 2023-9-16 12:37:57 | 只看該作者
A2輸入待修約數值,B2輸入保留小數點位數,C2輸入公式。對9.9999多的情況不適用,還待改進

IF(B2=0,IF(OR(AND(ISEVEN(INT(A2)),A2-INT(A2)=0.5),A2-INT(A2)<0.5),INT(A2),INT(A2)+1),IF(LEN(IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))=LEN(INT(A2)),IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2))&"."&REPT("0",B2),IF(LEN(INT(A2*POWER(10,B2)))+1>LEN((IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))),(IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))&REPT("0",LEN(INT(A2*POWER(10,B2)))-1-LEN((IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2))))),IF(OR(AND(ISEVEN(INT(A2*POWER(10,B2))),A2*POWER(10,B2)-INT(A2*POWER(10,B2))=0.5),A2*POWER(10,B2)-INT(A2*POWER(10,B2))<0.5),INT(A2*POWER(10,B2))/POWER(10,B2),(INT(A2*POWER(10,B2))+1)/POWER(10,B2)))))

保留多少位小數點.xlsx

9.5 KB, 下載次數: 1, 下載積分: 金幣 -1

12#
sunrry 發表于 2023-9-18 10:49:36 | 只看該作者
Function Round2(rng As Double, number As Integer) As Double
Round2 = Round(CDec(rng), number)
End Function


可以試試這個,最簡潔的方法,使用CDec函數進行強制轉換即可解決浮點小數的問題。參見
http://m.bkd208.com/forum.php?mod=viewthread&tid=223427
13#
wangyiyong7703 發表于 2023-9-18 19:47:48 | 只看該作者
sunrry 發表于 2023-9-18 10:49
Function Round2(rng As Double, number As Integer) As Double
Round2 = Round(CDec(rng), number)
End Fu ...

還用上VB ,如果用上VB,特殊情況大都可以解決。四舍六入的問題的邏輯語言很簡單,分為舍去的情況,剩下的就是進1的情況。即末位為偶數且舍去部分剛好為整5,或小于5的情況即可。實現各種特殊情況的才難點
14#
wangyiyong7703 發表于 2023-9-18 19:48:42 | 只看該作者
sunrry 發表于 2023-9-18 10:49
Function Round2(rng As Double, number As Integer) As Double
Round2 = Round(CDec(rng), number)
End Fu ...

我們力圖通過內建函數解決,這樣一般的人都可以通過電子表格實現使用
15#
sunrry 發表于 2023-9-22 14:58:09 | 只看該作者
wangyiyong7703 發表于 2023-9-18 19:48
我們力圖通過內建函數解決,這樣一般的人都可以通過電子表格實現使用

函數解決不了浮點小數的問題,總會有特例,雖然極小概率碰到
16#
wangyiyong7703 發表于 2023-9-22 17:16:01 | 只看該作者
sunrry 發表于 2023-9-22 14:58
函數解決不了浮點小數的問題,總會有特例,雖然極小概率碰到

你說一個浮點問題,看這個公式能否解決。也希望你多提問題,公式進一步改進,多幾個if而已
17#
fridayflyer 發表于 2023-9-23 23:24:09 | 只看該作者
好貼,必須要頂頂
您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|Archiver|計量論壇 ( 閩ICP備06005787號-1—304所 )
電話:0592-5613810 QQ:473647 微信:gfjlbbs閩公網安備 35020602000072號

GMT+8, 2025-12-21 05:06

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回復 返回頂部 返回列表
国产一区国产精品,2019中文亚洲字幕,电影在线高清,欧美精品一区二区三区久久
国产精品自拍网站| 午夜精品久久久久影视| 国产精品久线在线观看| 91麻豆视频网站| 欧美唯美清纯偷拍| 成人国产亚洲欧美成人综合网| 韩国在线一区二区| 偷窥国产亚洲免费视频| 国产一区二区三区久久悠悠色av| 国产一区二区不卡在线| 色婷婷久久久久swag精品| 日韩欧美中文字幕制服| 国产精品入口麻豆九色| 亚洲一区精品在线| 韩国三级在线一区| 欧美视频在线一区二区三区| 蜜桃av一区二区在线观看| 99久久国产综合色|国产精品| 国产麻豆欧美日韩一区| 在线视频欧美精品| 久久久亚洲精品一区二区三区 | 国产一区二区三区四区在线观看| 成人黄色免费短视频| 色综合色综合色综合色综合色综合 | 亚洲一区在线视频| 国产一区二区三区综合| 欧美三级电影在线看| 日本一区二区三区视频视频| 日韩精品电影一区亚洲| av一区二区不卡| 91在线视频观看| 欧美精品一区男女天堂| 亚洲裸体xxx| 国产精品一区二区久激情瑜伽 | 偷拍日韩校园综合在线| 成人性生交大片免费看视频在线| 综合欧美亚洲日本| 欧美揉bbbbb揉bbbbb| 18成人在线观看| 国产成人精品在线看| 欧美乱妇20p| 亚洲激情在线激情| 国产一区二区在线观看视频| 欧美一区二区三区男人的天堂| 中文字幕一区二| 成人高清在线视频| 日韩精品一区二区三区老鸭窝| 亚洲成人激情综合网| 午夜国产精品一区| 91成人网在线| 欧美日本国产视频| 午夜国产精品影院在线观看| youjizz国产精品| 国产精品嫩草99a| 成人理论电影网| 国产日本亚洲高清| 丁香婷婷综合色啪| 久久久久高清精品| 国产成人a级片| 国产精品亲子乱子伦xxxx裸| 国产不卡在线视频| 国产欧美一区二区精品性色超碰| 国产精品一区二区三区网站| 99久久伊人精品| 国产亚洲精品aa午夜观看| 久久99精品久久久久久动态图| 精品久久久久久久久久久久久久久久久| 麻豆极品一区二区三区| 精品国产亚洲在线| 精品一区二区三区免费观看| 国产偷v国产偷v亚洲高清| 日韩av中文在线观看| 欧美大片免费久久精品三p| 中文字幕中文在线不卡住| 91蜜桃传媒精品久久久一区二区| 中文字幕欧美日本乱码一线二线| 欧美美女网站色| 色偷偷久久一区二区三区| 国产精品主播直播| 美日韩一级片在线观看| 一区二区理论电影在线观看| 中文字幕不卡在线观看| 日韩精品影音先锋| 91.麻豆视频| 欧美老人xxxx18| 欧美午夜理伦三级在线观看| 福利一区在线观看| 国模娜娜一区二区三区| 日本视频一区二区三区| 亚洲一区电影777| 中文字幕免费不卡| 久久久久亚洲综合| 精品欧美久久久| 日韩欧美电影在线| 日韩一级完整毛片| 欧美一区二区三区啪啪| 欧美一区二区三区在| 91精品免费在线| 欧美变态凌虐bdsm| 亚洲精品在线观看网站| 久久夜色精品一区| 久久久久久久电影| 久久久精品欧美丰满| 国产午夜久久久久| 中文字幕成人在线观看| 国产精品夫妻自拍| 国产精品久久久久久久久动漫 | 欧美性色欧美a在线播放| 色综合天天天天做夜夜夜夜做| 成人h精品动漫一区二区三区| 国产成人精品亚洲777人妖| 国产精品1区二区.| 丁香婷婷综合激情五月色| 9l国产精品久久久久麻豆| 99精品视频在线观看| 色妞www精品视频| 欧美日韩午夜在线视频| 日韩欧美黄色影院| 亚洲国产视频a| 亚洲欧美激情在线| 五月天丁香久久| 韩国v欧美v日本v亚洲v| 成人av网站在线观看免费| 99精品黄色片免费大全| 欧美日韩国产片| 欧美videossexotv100| 久久综合久久综合亚洲| 国产精品素人一区二区| 一区二区三区视频在线看| 日韩成人一区二区三区在线观看| 极品少妇xxxx精品少妇| 成人av网址在线| 欧美日韩国产123区| 精品国产一区二区在线观看| 国产精品免费网站在线观看| 五月激情综合色| 国产成人免费av在线| 欧美亚洲一区二区在线观看| 欧美成人女星排行榜| 亚洲视频免费观看| 毛片av一区二区| 成人网在线播放| 欧美一区二区日韩| 中文一区一区三区高中清不卡| 亚洲国产精品一区二区www在线| 久久aⅴ国产欧美74aaa| 91网站最新地址| 久久蜜桃av一区精品变态类天堂 | 国产日韩三级在线| 亚洲成人激情av| 99久久综合狠狠综合久久| 日韩精品资源二区在线| 一区二区理论电影在线观看| 国产乱码字幕精品高清av| 欧美三区在线观看| 中文字幕一区二区视频| 极品尤物av久久免费看| 欧美另类高清zo欧美| 亚洲日本va午夜在线影院| 国产一区二区三区在线看麻豆| 欧美日韩国产小视频在线观看| 中文字幕中文乱码欧美一区二区| 午夜激情一区二区三区| 色呦呦国产精品| 国产精品美女一区二区在线观看| 亚洲色图一区二区三区| 国产自产v一区二区三区c| 欧美日韩国产另类不卡| 亚洲日本在线天堂| www.亚洲激情.com| 亚洲国产高清在线观看视频| 黑人巨大精品欧美黑白配亚洲| 欧美美女bb生活片| 亚洲一区二区不卡免费| 91在线云播放| 国产欧美精品国产国产专区| 精品在线亚洲视频| 日韩女优av电影在线观看| 肉色丝袜一区二区| 欧美日本一区二区| 天天综合网 天天综合色| 欧洲精品视频在线观看| 亚洲人成7777| 欧美精品一区二区精品网| 蜜臀久久99精品久久久画质超高清 | 色呦呦网站一区| 亚洲视频一二三| 色综合久久久久综合体| 国产精品电影院| 91丝袜呻吟高潮美腿白嫩在线观看| 国产日韩精品视频一区| 国产成人在线视频网站| 国产清纯美女被跳蛋高潮一区二区久久w | 婷婷国产v国产偷v亚洲高清| 欧美日韩国产综合一区二区三区 | 精品久久久久av影院 | 一区二区三区国产精品| 在线观看欧美黄色| 亚洲成年人影院| 欧美一区二区成人|