Please enable Javascript to view the contents

自定义Excel函数

 ·  ☕ 5 分钟  ·  👽 zhaoqiu

基础

通过Excel VBA编写特殊用途的函数,可以更方便地处理数据,提高效率。一般使用VBA中的Function来定义函数(Sub 不能提供返回值),即使含有自定义函数计算结果的xls文件在未安装自定义函数的电脑上打开,任然会正确显示结果,只是不能继续运算。

如何插入自定义的函数

新建Excel表格,(最好关闭别的Excel表),按alt + F11,点击插入,模块,添加代码。

Function示例

1
2
3
4
'Function 函数名(参数 As 类型) As 函数返回类型
Function Kelvin(temperature As Double) As Double
    Kelvin = temperature + 273.15
End Function

获取元素分子量

getMoles

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
Function GETMOLES(name)
    'author: zhaoqiu
    Dim Formula(124) As String
    Formula(0) = "SiO2"
    Formula(1) = "TiO2"
    Formula(2) = "Al2O3"
    ' ... ...
    Formula(122) = "NH3"
    Formula(123) = "NH4"
    Formula(124) = "NH4NO3"
    
    Dim MolecularWeight(124) As Double
    MolecularWeight(0) = 60.0843
    MolecularWeight(1) = 79.8988
    MolecularWeight(2) = 101.96128
    ' ... ...
    MolecularWeight(122) = 17.0304
    MolecularWeight(123) = 18.0383
    MolecularWeight(124) = 80.0432

    Dim oxideN As Long
    oxideN = UBound(Formula) - LBound(Formula) + 1
    Dim i As Long
    Dim result As Double
    result = -1
    For i = 0 To (oxideN - 1)
        If UCase(Trim(name)) = UCase(Formula(i)) Then
            result = MolecularWeight(i)
            Exit For
        Else
        End If
    Next
    If result = -1 Then
        GETMOLES = -1
    Else
        GETMOLES = result
    End If
End Function
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
Function GETMOLES(name)
    'author: zhaoqiu
    Dim Formula(124) As String
    Formula(0) = "SiO2"
    Formula(1) = "TiO2"
    Formula(2) = "Al2O3"
    Formula(3) = "Cr2O3"
    Formula(4) = "Fe2O3"
    Formula(5) = "FeO"
    Formula(6) = "MnO"
    Formula(7) = "MgO"
    Formula(8) = "CaO"
    Formula(9) = "Na2O"
    Formula(10) = "K2O"
    Formula(11) = "H2O"
    Formula(12) = "NiO"
    Formula(13) = "ZrO2"
    Formula(14) = "HfO2"
    Formula(15) = "H"
    Formula(16) = "He"
    Formula(17) = "Li"
    Formula(18) = "Be"
    Formula(19) = "B"
    Formula(20) = "C"
    Formula(21) = "N"
    Formula(22) = "O"
    Formula(23) = "F"
    Formula(24) = "Ne"
    Formula(25) = "Na"
    Formula(26) = "Mg"
    Formula(27) = "Al"
    Formula(28) = "Si"
    Formula(29) = "P"
    Formula(30) = "S"
    Formula(31) = "Cl"
    Formula(32) = "Ar"
    Formula(33) = "K"
    Formula(34) = "Ca"
    Formula(35) = "Sc"
    Formula(36) = "Ti"
    Formula(37) = "V"
    Formula(38) = "Cr"
    Formula(39) = "Mn"
    Formula(40) = "Fe"
    Formula(41) = "Co"
    Formula(42) = "Ni"
    Formula(43) = "Cu"
    Formula(44) = "Zn"
    Formula(45) = "Ga"
    Formula(46) = "Ge"
    Formula(47) = "As"
    Formula(48) = "Se"
    Formula(49) = "Br"
    Formula(50) = "Kr"
    Formula(51) = "Rb"
    Formula(52) = "Sr"
    Formula(53) = "Y"
    Formula(54) = "Zr"
    Formula(55) = "Nb"
    Formula(56) = "Mo"
    Formula(57) = "Tc"
    Formula(58) = "Ru"
    Formula(59) = "Rh"
    Formula(60) = "Pd"
    Formula(61) = "Ag"
    Formula(62) = "Cd"
    Formula(63) = "In"
    Formula(64) = "Sn"
    Formula(65) = "Sb"
    Formula(66) = "Te"
    Formula(67) = "I"
    Formula(68) = "Xe"
    Formula(69) = "Cs"
    Formula(70) = "Ba"
    Formula(71) = "La"
    Formula(72) = "Ce"
    Formula(73) = "Pr"
    Formula(74) = "Nd"
    Formula(75) = "Pm"
    Formula(76) = "Sm"
    Formula(77) = "Eu"
    Formula(78) = "Gd"
    Formula(79) = "Tb"
    Formula(80) = "Dy"
    Formula(81) = "Ho"
    Formula(82) = "Er"
    Formula(83) = "Tm"
    Formula(84) = "Yb"
    Formula(85) = "Lu"
    Formula(86) = "Hf"
    Formula(87) = "Ta"
    Formula(88) = "W"
    Formula(89) = "Re"
    Formula(90) = "Os"
    Formula(91) = "Ir"
    Formula(92) = "Pt"
    Formula(93) = "Au"
    Formula(94) = "Hg"
    Formula(95) = "Tl"
    Formula(96) = "Pb"
    Formula(97) = "Bi"
    Formula(98) = "Po"
    Formula(99) = "At"
    Formula(100) = "Rn"
    Formula(101) = "Fr"
    Formula(102) = "Ra"
    Formula(103) = "Ac"
    Formula(104) = "Th"
    Formula(105) = "Pa"
    Formula(106) = "U"
    Formula(107) = "Np"
    Formula(108) = "Pu"
    Formula(109) = "Am"
    Formula(110) = "Cm"
    Formula(111) = "Bk"
    Formula(112) = "Cf"
    Formula(113) = "Es"
    Formula(114) = "Fm"
    Formula(115) = "Md"
    Formula(116) = "No"
    Formula(117) = "SO3"
    Formula(118) = "P2O5"
    Formula(119) = "N2"
    Formula(120) = "CO2"
    Formula(121) = "CO"
    Formula(122) = "NH3"
    Formula(123) = "NH4"
    Formula(124) = "NH4NO3"
    ' molecular weight
    Dim MolecularWeight(124) As Double
    MolecularWeight(0) = 60.0843
    MolecularWeight(1) = 79.8988
    MolecularWeight(2) = 101.96128
    MolecularWeight(3) = 151.9902
    MolecularWeight(4) = 159.6922
    MolecularWeight(5) = 71.8464
    MolecularWeight(6) = 70.9374
    MolecularWeight(7) = 40.3044
    MolecularWeight(8) = 56.0794
    MolecularWeight(9) = 61.97894
    MolecularWeight(10) = 94.196
    MolecularWeight(11) = 18.0152
    MolecularWeight(12) = 74.6994
    MolecularWeight(13) = 123.218
    MolecularWeight(14) = 210.49
    MolecularWeight(15) = 1.0079
    MolecularWeight(16) = 4.0026
    MolecularWeight(17) = 6.941
    MolecularWeight(18) = 9.01218
    MolecularWeight(19) = 10.81
    MolecularWeight(20) = 12.011
    MolecularWeight(21) = 14.0067
    MolecularWeight(22) = 15.9994
    MolecularWeight(23) = 18.998403
    MolecularWeight(24) = 20.179
    MolecularWeight(25) = 22.98977
    MolecularWeight(26) = 24.305
    MolecularWeight(27) = 26.98154
    MolecularWeight(28) = 28.0855
    MolecularWeight(29) = 30.97376
    MolecularWeight(30) = 32.06
    MolecularWeight(31) = 35.453
    MolecularWeight(32) = 39.948
    MolecularWeight(33) = 39.0983
    MolecularWeight(34) = 40.08
    MolecularWeight(35) = 44.9559
    MolecularWeight(36) = 47.9
    MolecularWeight(37) = 50.9415
    MolecularWeight(38) = 51.996
    MolecularWeight(39) = 54.938
    MolecularWeight(40) = 55.847
    MolecularWeight(41) = 58.9332
    MolecularWeight(42) = 58.7
    MolecularWeight(43) = 63.546
    MolecularWeight(44) = 65.38
    MolecularWeight(45) = 69.72
    MolecularWeight(46) = 72.59
    MolecularWeight(47) = 74.9216
    MolecularWeight(48) = 78.96
    MolecularWeight(49) = 79.904
    MolecularWeight(50) = 83.8
    MolecularWeight(51) = 85.4678
    MolecularWeight(52) = 87.62
    MolecularWeight(53) = 88.9059
    MolecularWeight(54) = 91.22
    MolecularWeight(55) = 92.9064
    MolecularWeight(56) = 95.94
    MolecularWeight(57) = 98
    MolecularWeight(58) = 101.07
    MolecularWeight(59) = 102.9055
    MolecularWeight(60) = 106.4
    MolecularWeight(61) = 107.868
    MolecularWeight(62) = 112.41
    MolecularWeight(63) = 114.82
    MolecularWeight(64) = 118.69
    MolecularWeight(65) = 121.75
    MolecularWeight(66) = 127.6
    MolecularWeight(67) = 126.9045
    MolecularWeight(68) = 131.3
    MolecularWeight(69) = 132.9054
    MolecularWeight(70) = 137.33
    MolecularWeight(71) = 138.9055
    MolecularWeight(72) = 140.12
    MolecularWeight(73) = 140.9077
    MolecularWeight(74) = 144.24
    MolecularWeight(75) = 145
    MolecularWeight(76) = 150.4
    MolecularWeight(77) = 151.96
    MolecularWeight(78) = 157.25
    MolecularWeight(79) = 158.9254
    MolecularWeight(80) = 162.5
    MolecularWeight(81) = 164.9304
    MolecularWeight(82) = 167.26
    MolecularWeight(83) = 168.9342
    MolecularWeight(84) = 173.04
    MolecularWeight(85) = 174.967
    MolecularWeight(86) = 178.49
    MolecularWeight(87) = 180.9479
    MolecularWeight(88) = 183.85
    MolecularWeight(89) = 186.207
    MolecularWeight(90) = 190.2
    MolecularWeight(91) = 192.22
    MolecularWeight(92) = 195.09
    MolecularWeight(93) = 196.9665
    MolecularWeight(94) = 200.59
    MolecularWeight(95) = 204.37
    MolecularWeight(96) = 207.2
    MolecularWeight(97) = 208.9804
    MolecularWeight(98) = 209
    MolecularWeight(99) = 210
    MolecularWeight(100) = 222
    MolecularWeight(101) = 223
    MolecularWeight(102) = 226.0254
    MolecularWeight(103) = 227.0278
    MolecularWeight(104) = 232.0381
    MolecularWeight(105) = 231.0359
    MolecularWeight(106) = 238.029
    MolecularWeight(107) = 237.0482
    MolecularWeight(108) = 244
    MolecularWeight(109) = 243
    MolecularWeight(110) = 247
    MolecularWeight(111) = 247
    MolecularWeight(112) = 251
    MolecularWeight(113) = 252
    MolecularWeight(114) = 257
    MolecularWeight(115) = 258
    MolecularWeight(116) = 259
    MolecularWeight(117) = 80.0582
    MolecularWeight(118) = 141.94452
    MolecularWeight(119) = 28.0134
    MolecularWeight(120) = 44.0098
    MolecularWeight(121) = 28.0104
    MolecularWeight(122) = 17.0304
    MolecularWeight(123) = 18.0383
    MolecularWeight(124) = 80.0432
    ' UBound 返回数组最大下标 LBound 返回数组的最小下标即0
    Dim oxideN As Long
    oxideN = UBound(Formula) - LBound(Formula) + 1
    Dim i As Long
    Dim result As Double
    result = -1
    For i = 0 To (oxideN - 1)
        ' 将所有字符串转换成大写
        If UCase(Trim(name)) = UCase(Formula(i)) Then
            result = MolecularWeight(i)
            Exit For
        Else
        End If
    Next
    If result = -1 Then
        GETMOLES = -1
    Else
        GETMOLES = result
    End If
End Function

去除从ScienceDirect网页上直接复制的数据的非数字格式

搜集文献数据的时候,如果文献没有提供单独的excel文件,最佳的复制数据的方式是从文献对应的网页版上复制,但ScienceDirect上的页面是经过特殊渲染过的,比如负号-并不是真正的负号,另外类似-11.63(221), 58.5 ± 2·3等数据+误差的格式也需要后续处理。

getNumber

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
Function GETNUMBER(text)

    temptext = text
    text = Trim(text)
    If Len(text) > 0 Then
    
        If Not IsNumeric(text) Then
            
            ' 常见格式:2.48(5)  2.48 (5)  2.48 ±2  3·52?  2.48(5) 1,000
            ' 区分需要替换的符号和去除的符号
            ' 需要去除的
            Dim BlankIndex As Long
            BlankIndex = InStr(1, text, " ")
            If BlankIndex = 0 Then
                BlankIndex = 100000
            End If
                
            
            Dim LeftBracketIndex As Long
            LeftBracketIndex = InStr(1, text, "(")
            If LeftBracketIndex = 0 Then
                LeftBracketIndex = 100000
            End If
            
            Dim RightBracketIndex As Long
            RightBracketIndex = InStr(1, text, ")")
            If RightBracketIndex = 0 Then
                RightBracketIndex = 100000
            End If
            
            Dim QuestionMarkIndex As Long
            QuestionMarkIndex = InStr(1, text, "?")
            If QuestionMarkIndex = 0 Then
                QuestionMarkIndex = 100000
            End If
           
            Dim PlusMinusIndex As Long
            PlusMinusIndex = InStr(1, text, "±")
            If PlusMinusIndex = 0 Then
                PlusMinusIndex = 100000
            End If

            
            minindex = WorksheetFunction.Min(BlankIndex, LeftBracketIndex, RightBracketIndex, QuestionMarkIndex, PlusMinusIndex)
            
            If minindex < 100000 Then
            
                text = Left(text, minindex - 1)
            End If
            
                                    
            ' 需要替换的
            Dim DotIndex As Long
            DotIndex = InStr(1, text, "·")
            If Not DotIndex = 0 Then
                text = Replace(text, "·", ".", 1, 1)
            End If
            
            Dim CommaIndex As Long
            CommaIndex = InStr(1, text, ",")
            If Not CommaIndex = 0 Then
                text = Replace(text, ",", "", 1, 1)
            End If
            
           
            
            If Val(text) = 0 Then
            
            
                If Len(text) > 1 Then
                
                   If (Asc(Left(text, 1)) >= 65 And Asc(Left(text, 1)) <= 90) Or (Asc(Left(text, 1)) >= 97 And Asc(Left(text, 1)) <= 122) Then
                   
                       GETNUMBER = temptext
                   Else
                       GETNUMBER = Val("-" & Right(text, Len(text) - 1))
        
                   End If
                Else
                    GETNUMBER = temptext
                    
                End If
                    
            Else
                
                GETNUMBER = Val(text)
            End If
            
            
        Else

            GETNUMBER = Val(text)
        End If
    End If
    
    

End Function

提取误差

待完成

分享