Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
K
klck
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
位宇华
klck
Commits
fabc3ad7
Commit
fabc3ad7
authored
May 30, 2024
by
Fuzy
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
重构计算方法
parent
b6ed6281
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
35 additions
and
47 deletions
+35
-47
ruoyi-wages/src/main/java/com/ruoyi/system/service/impl/WagesCalculateConversionServiceImpl.java
...tem/service/impl/WagesCalculateConversionServiceImpl.java
+34
-46
ruoyi-wages/src/main/java/com/ruoyi/system/service/impl/WagesConversionServiceImpl.java
...ruoyi/system/service/impl/WagesConversionServiceImpl.java
+1
-1
No files found.
ruoyi-wages/src/main/java/com/ruoyi/system/service/impl/WagesCalculateConversionServiceImpl.java
View file @
fabc3ad7
...
...
@@ -240,58 +240,46 @@ public class WagesCalculateConversionServiceImpl implements WagesCalculateConver
if
(
pattern
.
matcher
(
value
).
matches
())
{
return
value
;
}
boolean
a
=
true
;
boolean
b
=
true
;
int
a1
=
-
1
;
int
b1
=
-
1
;
// 判断是否为 x + y
boolean
ifAccordOne
=
true
;
// 判断是否为 x + y + z + ...
boolean
ifAccordTwo
=
true
;
// 记录第一个符合位置
int
accordPositionOne
=
-
1
;
// 记录第二个符合位置
int
accordPositionTwo
=
value
.
length
();
for
(
int
i
=
0
;
i
<
value
.
length
();
i
++)
{
char
charAt
=
value
.
charAt
(
i
);
if
(
FH
.
contains
(
charAt
)
&&
!
a
&&
b
)
{
b
=
false
;
b1
=
i
;
if
(
FH
.
contains
(
charAt
)
&&
!
ifAccordOne
&&
ifAccordTwo
)
{
ifAccordTwo
=
false
;
accordPositionTwo
=
i
;
break
;
}
if
(
FH
.
contains
(
charAt
)
&&
a
)
{
a
=
false
;
a1
=
i
;
}
else
if
(
FH
.
contains
(
charAt
))
{
ifAccordOne
=
false
;
accordPositionOne
=
i
;
}
}
if
(
b
)
{
String
sta
=
value
.
substring
(
0
,
a1
);
String
end
=
value
.
substring
(
a1
+
1
);
char
charAt
=
value
.
substring
(
a1
,
a1
+
1
).
charAt
(
0
);
if
(
charAt
==
42
)
{
//*
return
new
BigDecimal
(
sta
).
multiply
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
43
)
{
// +
return
new
BigDecimal
(
sta
).
add
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
45
)
{
// -
return
new
BigDecimal
(
sta
).
subtract
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
47
)
{
// /
return
new
BigDecimal
(
sta
).
divide
(
new
BigDecimal
(
end
)).
toString
();
}
String
sta
=
value
.
substring
(
0
,
accordPositionOne
);
String
end
=
value
.
substring
(
accordPositionOne
+
1
,
accordPositionTwo
);
char
charAt
=
value
.
substring
(
accordPositionOne
,
accordPositionOne
+
1
).
charAt
(
0
);
String
jg
=
""
;
if
(
charAt
==
42
)
{
//*
jg
=
new
BigDecimal
(
sta
).
multiply
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
43
)
{
// +
jg
=
new
BigDecimal
(
sta
).
add
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
45
)
{
// -
jg
=
new
BigDecimal
(
sta
).
subtract
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
47
)
{
// /
jg
=
new
BigDecimal
(
sta
).
divide
(
new
BigDecimal
(
end
)).
toString
();
}
if
(
ifAccordTwo
)
{
return
jg
;
}
else
{
String
sta
=
value
.
substring
(
0
,
a1
);
String
end
=
value
.
substring
(
a1
+
1
,
b1
);
char
charAt
=
value
.
substring
(
a1
,
a1
+
1
).
charAt
(
0
);
String
jg
=
""
;
if
(
charAt
==
42
)
{
//*
jg
=
new
BigDecimal
(
sta
).
multiply
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
43
)
{
// +
jg
=
new
BigDecimal
(
sta
).
add
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
45
)
{
// -
jg
=
new
BigDecimal
(
sta
).
subtract
(
new
BigDecimal
(
end
)).
toString
();
}
else
if
(
charAt
==
47
)
{
// /
jg
=
new
BigDecimal
(
sta
).
divide
(
new
BigDecimal
(
end
)).
toString
();
}
String
s
=
StringUtils
.
replaceOnce
(
value
,
value
.
substring
(
0
,
b1
),
jg
);
String
s
=
StringUtils
.
replaceOnce
(
value
,
value
.
substring
(
0
,
accordPositionTwo
),
jg
);
value
=
count1
(
s
);
}
return
value
;
...
...
ruoyi-wages/src/main/java/com/ruoyi/system/service/impl/WagesConversionServiceImpl.java
View file @
fabc3ad7
...
...
@@ -51,7 +51,7 @@ public class WagesConversionServiceImpl implements WagesConversionService {
boolean
b1
=
list
.
parallelStream
().
anyMatch
(
v
->
v
.
getYearMonth
()
==
null
||
v
.
getYearMonth
().
indexOf
(
"-"
)
<=
0
);
if
(
b1
)
return
"数据库中数据存在日期错误"
;
Optional
<
Integer
>
max
=
list
.
parallelStream
().
map
(
v
->
Integer
.
parseInt
(
v
.
getYearMonth
().
split
(
"-"
)[
0
])).
max
((
a
,
b
)
->
a
-
b
);
List
<
WagesConversionDataVO
>
collect
=
null
;
List
<
WagesConversionDataVO
>
collect
;
if
(
max
.
isPresent
()){
collect
=
list
.
parallelStream
().
filter
(
v
->
v
.
getYearMonth
().
split
(
"-"
)[
0
].
equals
(
max
.
get
()
+
""
)).
collect
(
Collectors
.
toList
());
}
else
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment