Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
W
wangxiaolu-export
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
promotion
wangxiaolu-export
Commits
93856473
提交
93856473
authored
10月 28, 2024
作者:
李秋林
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
推送飞书-添加上下班打卡间隔时间(小时)
上级
2deff724
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
43 行增加
和
18 行删除
+43
-18
.gitignore
.gitignore
+1
-0
ActivityToFeishuSheetServiceImpl.java
...export/service/impl/ActivityToFeishuSheetServiceImpl.java
+27
-18
WangxiaoluExportApplicationTests.java
...m/wangxiaolu/export/WangxiaoluExportApplicationTests.java
+15
-0
没有找到文件。
.gitignore
浏览文件 @
93856473
...
...
@@ -28,6 +28,7 @@ target/
build/
!**/src/main/**/build/
!**/src/test/**/build/
/logs
### VS Code ###
.vscode/
src/main/java/com/wangxiaolu/export/service/impl/ActivityToFeishuSheetServiceImpl.java
浏览文件 @
93856473
package
com
.
wangxiaolu
.
export
.
service
.
impl
;
import
cn.hutool.core.date.DateUnit
;
import
cn.hutool.core.date.DateUtil
;
import
com.alibaba.fastjson.JSONObject
;
import
com.wangxiaolu.export.mapper.FeishuSheetRecordMapper
;
...
...
@@ -18,6 +19,7 @@ import org.springframework.beans.factory.annotation.Value;
import
org.springframework.stereotype.Service
;
import
org.springframework.util.CollectionUtils
;
import
javax.swing.*
;
import
java.util.*
;
import
java.util.stream.Collectors
;
...
...
@@ -148,12 +150,19 @@ public class ActivityToFeishuSheetServiceImpl implements ActivityToFeishuSheetSe
// S-V: 上班打卡时间/地点 午休下班打卡时间/地点 午休上班打卡时间/地点 下班打卡时间/地点
if
(
Objects
.
nonNull
(
clockDo
)){
List
<
Object
>
rowClockData
=
new
ArrayList
<>();
if
(
Objects
.
nonNull
(
clockDo
.
getClockInTime
())
&&
Objects
.
nonNull
(
clockDo
.
getClockOutTime
())){
long
tl
=
DateUtil
.
between
(
clockDo
.
getClockInTime
(),
clockDo
.
getClockOutTime
(),
DateUnit
.
MINUTE
);
long
hour
=
tl
/
60
;
long
minute
=
tl
%
60
;
rowClockData
.
add
(
String
.
valueOf
(
hour
)
+
minute
);
}
else
{
rowClockData
.
add
(
"0"
);
}
rowClockData
.
add
(
"【"
+
DateUtil
.
formatDateTime
(
clockDo
.
getClockInTime
())+
"】"
+
clockDo
.
getClockInAddress
());
rowClockData
.
add
(
"【"
+
DateUtil
.
formatDateTime
(
clockDo
.
getNoonClockOutTime
())+
"】"
+
clockDo
.
getNoonClockOutAddress
());
rowClockData
.
add
(
"【"
+
DateUtil
.
formatDateTime
(
clockDo
.
getNoonClockInTime
())+
"】"
+
clockDo
.
getNoonClockInAddress
());
rowClockData
.
add
(
"【"
+
DateUtil
.
formatDateTime
(
clockDo
.
getClockOutTime
())+
"】"
+
clockDo
.
getClockOutAddress
());
String
range
=
String
.
format
(
rangFormat
,
"S"
,
"V"
);
String
range
=
String
.
format
(
rangFormat
,
"S"
,
"W"
);
updateClockData
(
range
,
rowClockData
);
}
...
...
@@ -200,22 +209,22 @@ public class ActivityToFeishuSheetServiceImpl implements ActivityToFeishuSheetSe
Map
<
Integer
,
String
>
clockMap
=
activityClock
.
stream
().
collect
(
Collectors
.
toMap
(
TemporaryActivityPhotoDO:
:
getType
,
TemporaryActivityPhotoDO:
:
getPhotoUrl
));
// 上班打卡照片 >>>
if
(
clockMap
.
containsKey
(
4
))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"
W"
,
"W
"
),
clockMap
.
get
(
4
));
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"
X"
,
"X
"
),
clockMap
.
get
(
4
));
}
// 午休下班打卡照片 >>>
if
(
clockMap
.
containsKey
(
5
))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"
X"
,
"X
"
),
clockMap
.
get
(
5
));
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"
Y"
,
"Y
"
),
clockMap
.
get
(
5
));
}
// 午休上班打卡照片 >>>
if
(
clockMap
.
containsKey
(
6
))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"
Y"
,
"Y
"
),
clockMap
.
get
(
6
));
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"
Z"
,
"Z
"
),
clockMap
.
get
(
6
));
}
// 下班打卡照片 >>>
if
(
clockMap
.
containsKey
(
7
))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"
Z"
,
"Z
"
),
clockMap
.
get
(
7
));
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"
AA"
,
"AA
"
),
clockMap
.
get
(
7
));
}
log
.
info
(
"上传打卡照片完成,行号:{}"
,
rowNumStr
);
...
...
@@ -226,22 +235,22 @@ public class ActivityToFeishuSheetServiceImpl implements ActivityToFeishuSheetSe
int
photosType1Size
=
photosType1
.
size
();
// 推广试吃照片1 >>>
if
(!(
photosType1Size
<
1
||
Objects
.
isNull
(
photosType1
.
get
(
0
))))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
A"
,
"AA
"
),
photosType1
.
get
(
0
).
getPhotoUrl
());
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
B"
,
"AB
"
),
photosType1
.
get
(
0
).
getPhotoUrl
());
}
// 推广试吃照片2 >>>
if
(!(
photosType1Size
<
2
||
Objects
.
isNull
(
photosType1
.
get
(
1
))))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
B"
,
"AB
"
),
photosType1
.
get
(
1
).
getPhotoUrl
());
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
C"
,
"AC
"
),
photosType1
.
get
(
1
).
getPhotoUrl
());
}
// 推广试吃照片3 >>>
if
(!(
photosType1Size
<
3
||
Objects
.
isNull
(
photosType1
.
get
(
2
))))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
C"
,
"AC
"
),
photosType1
.
get
(
2
).
getPhotoUrl
());
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
D"
,
"AD
"
),
photosType1
.
get
(
2
).
getPhotoUrl
());
}
// 推广试吃照片4 >>>
if
(!(
photosType1Size
<
4
||
Objects
.
isNull
(
photosType1
.
get
(
3
))))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
D"
,
"AD
"
),
photosType1
.
get
(
3
).
getPhotoUrl
());
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
E"
,
"AE
"
),
photosType1
.
get
(
3
).
getPhotoUrl
());
}
log
.
info
(
"上传推广-试吃照片完成,行号:{}"
,
rowNumStr
);
...
...
@@ -252,22 +261,22 @@ public class ActivityToFeishuSheetServiceImpl implements ActivityToFeishuSheetSe
int
photosType2Size
=
photosType2
.
size
();
// 推广互动照片1 >>>
if
(!(
photosType2Size
<
1
||
Objects
.
isNull
(
photosType2
.
get
(
0
))))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
E"
,
"AE
"
),
photosType2
.
get
(
0
).
getPhotoUrl
());
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
F"
,
"AF
"
),
photosType2
.
get
(
0
).
getPhotoUrl
());
}
// 推广互动照片2 >>>
if
(!(
photosType2Size
<
2
||
Objects
.
isNull
(
photosType2
.
get
(
1
))))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
F"
,
"AF
"
),
photosType2
.
get
(
1
).
getPhotoUrl
());
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
G"
,
"AG
"
),
photosType2
.
get
(
1
).
getPhotoUrl
());
}
// 推广互动照片3 >>>
if
(!(
photosType2Size
<
3
||
Objects
.
isNull
(
photosType2
.
get
(
2
))))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
G"
,
"AG
"
),
photosType2
.
get
(
2
).
getPhotoUrl
());
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
H"
,
"AH
"
),
photosType2
.
get
(
2
).
getPhotoUrl
());
}
// 推广互动照片4 >>>
if
(!(
photosType2Size
<
4
||
Objects
.
isNull
(
photosType2
.
get
(
3
))))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
H"
,
"AH
"
),
photosType2
.
get
(
3
).
getPhotoUrl
());
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
I"
,
"AI
"
),
photosType2
.
get
(
3
).
getPhotoUrl
());
}
log
.
info
(
"上传推广-互动照片完成,行号:{}"
,
rowNumStr
);
...
...
@@ -278,22 +287,22 @@ public class ActivityToFeishuSheetServiceImpl implements ActivityToFeishuSheetSe
int
photosType3Size
=
photosType3
.
size
();
// 推广成交照片1 >>>
if
(!(
photosType3Size
<
1
||
Objects
.
isNull
(
photosType3
.
get
(
0
))))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
I"
,
"AI
"
),
photosType3
.
get
(
0
).
getPhotoUrl
());
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
J"
,
"AJ
"
),
photosType3
.
get
(
0
).
getPhotoUrl
());
}
// 推广成交照片2 >>>
if
(!(
photosType3Size
<
2
||
Objects
.
isNull
(
photosType3
.
get
(
1
))))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
J"
,
"AJ
"
),
photosType3
.
get
(
1
).
getPhotoUrl
());
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
K"
,
"AK
"
),
photosType3
.
get
(
1
).
getPhotoUrl
());
}
// 推广成交照片3 >>>
if
(!(
photosType3Size
<
3
||
Objects
.
isNull
(
photosType3
.
get
(
2
))))
{
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
K"
,
"AK
"
),
photosType3
.
get
(
2
).
getPhotoUrl
());
valuesImageToSheet
(
String
.
format
(
rangFormat
,
"A
L"
,
"AL
"
),
photosType3
.
get
(
2
).
getPhotoUrl
());
}
// 推广成交照片4 >>>
if
(!(
photosType3Size
<
4
||
Objects
.
isNull
(
photosType3
.
get
(
3
))))
{
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
L"
,
"AL
"
),
photosType3
.
get
(
3
).
getPhotoUrl
());
valuesImageToSheetByRobot2
(
String
.
format
(
rangFormat
,
"A
M"
,
"AM
"
),
photosType3
.
get
(
3
).
getPhotoUrl
());
}
log
.
info
(
"上传推广-成交照片完成,行号:{}"
,
rowNumStr
);
}
...
...
src/test/java/com/wangxiaolu/export/WangxiaoluExportApplicationTests.java
浏览文件 @
93856473
package
com
.
wangxiaolu
.
export
;
import
cn.hutool.core.date.DateUnit
;
import
cn.hutool.core.date.DateUtil
;
import
org.junit.jupiter.api.Test
;
import
org.springframework.boot.test.context.SpringBootTest
;
import
java.util.Date
;
@SpringBootTest
class
WangxiaoluExportApplicationTests
{
@Test
void
contextLoads
()
{
Date
date1
=
new
Date
(
2024
,
10
,
28
,
10
,
02
);
Date
date2
=
new
Date
(
2024
,
10
,
28
,
14
,
46
);
long
between1
=
DateUtil
.
between
(
date1
,
date2
,
DateUnit
.
HOUR
);
long
between2
=
DateUtil
.
between
(
date1
,
date2
,
DateUnit
.
MINUTE
)
/
60
;
System
.
out
.
println
(
between1
);
System
.
out
.
println
(
between2
);
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论