Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
Education
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
黄奎
Education
Commits
d10ca602
Commit
d10ca602
authored
Mar 02, 2022
by
黄奎
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
页面修改
parent
1d996a06
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
707 additions
and
705 deletions
+707
-705
StudentStatModule.cs
Edu.Module.User/StudentStatModule.cs
+707
-705
No files found.
Edu.Module.User/StudentStatModule.cs
View file @
d10ca602
...
@@ -1629,7 +1629,7 @@ namespace Edu.Module.User
...
@@ -1629,7 +1629,7 @@ namespace Edu.Module.User
List
<
RateYearItem
>
yearList
=
new
List
<
RateYearItem
>();
List
<
RateYearItem
>
yearList
=
new
List
<
RateYearItem
>();
List
<
RB_Student_Static_Extend
>
rateList
=
new
List
<
RB_Student_Static_Extend
>();
List
<
RB_Student_Static_Extend
>
rateList
=
new
List
<
RB_Student_Static_Extend
>();
var
list
=
student_StaticRepository
.
GetStudentStaticYearListRepository
(
query
);
var
list
=
student_StaticRepository
.
GetStudentStaticYearListRepository
(
query
);
if
(
list
!=
null
)
if
(
list
!=
null
&&
list
.
Count
>
0
)
{
{
int
minYear
=
list
.
Min
(
qitem
=>
qitem
.
YearStr
);
int
minYear
=
list
.
Min
(
qitem
=>
qitem
.
YearStr
);
int
maxYear
=
list
.
Max
(
qitem
=>
qitem
.
YearStr
);
int
maxYear
=
list
.
Max
(
qitem
=>
qitem
.
YearStr
);
...
@@ -1834,15 +1834,15 @@ namespace Edu.Module.User
...
@@ -1834,15 +1834,15 @@ namespace Edu.Module.User
StudyOrderMoney
=
StudyOrderMoney
,
StudyOrderMoney
=
StudyOrderMoney
,
});
});
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"推送人数"
,
ItemName
=
"推送人数"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
list
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
minYear
).
PushCount
,
2
),
FirstYear
=
Math
.
Round
(
list
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
minYear
).
PushCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
list
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
PushCount
,
2
),
SecondYear
=
Math
.
Round
(
list
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
PushCount
,
2
),
YearRate
=
Math
.
Round
(
rateList
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
PushCount
,
2
),
YearRate
=
Math
.
Round
(
rateList
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
PushCount
,
2
),
});
});
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
...
@@ -2145,7 +2145,6 @@ namespace Edu.Module.User
...
@@ -2145,7 +2145,6 @@ namespace Edu.Module.User
YearRate
=
Math
.
Round
(
rateList
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
StudyOrderMoney
,
2
),
YearRate
=
Math
.
Round
(
rateList
.
FirstOrDefault
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
StudyOrderMoney
,
2
),
});
});
}
}
return
yearList
;
return
yearList
;
}
}
...
@@ -2158,744 +2157,747 @@ namespace Edu.Module.User
...
@@ -2158,744 +2157,747 @@ namespace Edu.Module.User
{
{
List
<
RateYearItem
>
yearList
=
new
List
<
RateYearItem
>();
List
<
RateYearItem
>
yearList
=
new
List
<
RateYearItem
>();
var
dataList
=
student_StaticRepository
.
GetStudentStaticMonthListRepository
(
query
,
isYear
:
true
);
var
dataList
=
student_StaticRepository
.
GetStudentStaticMonthListRepository
(
query
,
isYear
:
true
);
List
<
RB_Student_Static_Extend
>
result
=
new
List
<
RB_Student_Static_Extend
>();
if
(
dataList
!=
null
&&
dataList
.
Count
>
0
)
int
minYear
=
dataList
.
Min
(
qitem
=>
qitem
.
YearStr
);
int
maxYear
=
dataList
.
Max
(
qitem
=>
qitem
.
YearStr
);
var
totalYear
=
maxYear
-
minYear
;
for
(
var
y
=
0
;
y
<=
totalYear
;
y
++)
{
{
var
list
=
dataList
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
+
y
).
ToList
();
List
<
RB_Student_Static_Extend
>
result
=
new
List
<
RB_Student_Static_Extend
>();
for
(
var
i
=
0
;
i
<
12
;
i
++)
int
minYear
=
dataList
.
Min
(
qitem
=>
qitem
.
YearStr
);
int
maxYear
=
dataList
.
Max
(
qitem
=>
qitem
.
YearStr
);
var
totalYear
=
maxYear
-
minYear
;
for
(
var
y
=
0
;
y
<=
totalYear
;
y
++)
{
{
decimal
PushCount
=
0
;
var
list
=
dataList
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
+
y
).
ToList
();
var
firstModel
=
new
RB_Student_Static_Extend
();
for
(
var
i
=
0
;
i
<
12
;
i
++)
if
(
i
>
0
)
{
firstModel
=
i
<
list
.
Count
?
list
[
i
-
1
]
:
new
RB_Student_Static_Extend
();
}
var
item
=
i
<
list
.
Count
?
list
[
i
]
:
new
RB_Student_Static_Extend
();
if
(
firstModel
.
PushCount
>
0
&&
i
>
0
)
{
PushCount
=
(
item
.
PushCount
-
firstModel
.
PushCount
)
/
firstModel
.
PushCount
*
100
;
}
decimal
NewCount
=
0
;
if
(
firstModel
.
NewCount
>
0
&&
i
>
0
)
{
{
NewCount
=
(
item
.
NewCount
-
firstModel
.
NewCount
)
/
firstModel
.
NewCount
*
100
;
decimal
PushCount
=
0
;
}
var
firstModel
=
new
RB_Student_Static_Extend
();
if
(
i
>
0
)
{
firstModel
=
i
<
list
.
Count
?
list
[
i
-
1
]
:
new
RB_Student_Static_Extend
();
}
var
item
=
i
<
list
.
Count
?
list
[
i
]
:
new
RB_Student_Static_Extend
();
if
(
firstModel
.
PushCount
>
0
&&
i
>
0
)
{
PushCount
=
(
item
.
PushCount
-
firstModel
.
PushCount
)
/
firstModel
.
PushCount
*
100
;
}
decimal
NewCount
=
0
;
if
(
firstModel
.
NewCount
>
0
&&
i
>
0
)
{
NewCount
=
(
item
.
NewCount
-
firstModel
.
NewCount
)
/
firstModel
.
NewCount
*
100
;
}
decimal
CommunicationCount
=
0
;
decimal
CommunicationCount
=
0
;
if
(
firstModel
.
CommunicationCount
>
0
&&
i
>
0
)
if
(
firstModel
.
CommunicationCount
>
0
&&
i
>
0
)
{
{
CommunicationCount
=
(
item
.
CommunicationCount
-
firstModel
.
CommunicationCount
)
/
firstModel
.
CommunicationCount
*
100
;
CommunicationCount
=
(
item
.
CommunicationCount
-
firstModel
.
CommunicationCount
)
/
firstModel
.
CommunicationCount
*
100
;
}
}
decimal
TrialLessonCount
=
0
;
decimal
TrialLessonCount
=
0
;
if
(
firstModel
.
TrialLessonCount
>
0
&&
i
>
0
)
if
(
firstModel
.
TrialLessonCount
>
0
&&
i
>
0
)
{
{
TrialLessonCount
=
(
item
.
TrialLessonCount
-
firstModel
.
TrialLessonCount
)
/
firstModel
.
TrialLessonCount
*
100
;
TrialLessonCount
=
(
item
.
TrialLessonCount
-
firstModel
.
TrialLessonCount
)
/
firstModel
.
TrialLessonCount
*
100
;
}
}
decimal
NotContacted
=
0
;
decimal
NotContacted
=
0
;
if
(
firstModel
.
NotContacted
>
0
&&
i
>
0
)
if
(
firstModel
.
NotContacted
>
0
&&
i
>
0
)
{
{
NotContacted
=
(
item
.
NotContacted
-
firstModel
.
NotContacted
)
/
firstModel
.
NotContacted
*
100
;
NotContacted
=
(
item
.
NotContacted
-
firstModel
.
NotContacted
)
/
firstModel
.
NotContacted
*
100
;
}
}
decimal
JPCount
=
0
;
decimal
JPCount
=
0
;
if
(
firstModel
.
JPCount
>
0
&&
i
>
0
)
if
(
firstModel
.
JPCount
>
0
&&
i
>
0
)
{
{
JPCount
=
(
item
.
JPCount
-
firstModel
.
JPCount
)
/
firstModel
.
JPCount
*
100
;
JPCount
=
(
item
.
JPCount
-
firstModel
.
JPCount
)
/
firstModel
.
JPCount
*
100
;
}
}
decimal
KRCount
=
0
;
decimal
KRCount
=
0
;
if
(
firstModel
.
KRCount
>
0
&&
i
>
0
)
if
(
firstModel
.
KRCount
>
0
&&
i
>
0
)
{
{
KRCount
=
(
item
.
KRCount
-
firstModel
.
KRCount
)
/
firstModel
.
KRCount
*
100
;
KRCount
=
(
item
.
KRCount
-
firstModel
.
KRCount
)
/
firstModel
.
KRCount
*
100
;
}
}
decimal
FRCount
=
0
;
decimal
FRCount
=
0
;
if
(
firstModel
.
FRCount
>
0
&&
i
>
0
)
if
(
firstModel
.
FRCount
>
0
&&
i
>
0
)
{
{
FRCount
=
(
item
.
FRCount
-
firstModel
.
FRCount
)
/
firstModel
.
FRCount
*
100
;
FRCount
=
(
item
.
FRCount
-
firstModel
.
FRCount
)
/
firstModel
.
FRCount
*
100
;
}
}
decimal
JPStudyCount
=
0
;
decimal
JPStudyCount
=
0
;
if
(
firstModel
.
JPStudyCount
>
0
&&
i
>
0
)
if
(
firstModel
.
JPStudyCount
>
0
&&
i
>
0
)
{
{
JPStudyCount
=
(
item
.
JPStudyCount
-
firstModel
.
JPStudyCount
)
/
firstModel
.
JPStudyCount
*
100
;
JPStudyCount
=
(
item
.
JPStudyCount
-
firstModel
.
JPStudyCount
)
/
firstModel
.
JPStudyCount
*
100
;
}
}
decimal
KRStudyCount
=
0
;
decimal
KRStudyCount
=
0
;
if
(
firstModel
.
KRStudyCount
>
0
&&
i
>
0
)
if
(
firstModel
.
KRStudyCount
>
0
&&
i
>
0
)
{
{
KRStudyCount
=
(
item
.
KRStudyCount
-
firstModel
.
KRStudyCount
)
/
firstModel
.
KRStudyCount
*
100
;
KRStudyCount
=
(
item
.
KRStudyCount
-
firstModel
.
KRStudyCount
)
/
firstModel
.
KRStudyCount
*
100
;
}
}
decimal
YGAStudyCount
=
0
;
decimal
YGAStudyCount
=
0
;
if
(
firstModel
.
YGAStudyCount
>
0
&&
i
>
0
)
if
(
firstModel
.
YGAStudyCount
>
0
&&
i
>
0
)
{
{
YGAStudyCount
=
(
item
.
YGAStudyCount
-
firstModel
.
YGAStudyCount
)
/
firstModel
.
YGAStudyCount
*
100
;
YGAStudyCount
=
(
item
.
YGAStudyCount
-
firstModel
.
YGAStudyCount
)
/
firstModel
.
YGAStudyCount
*
100
;
}
}
decimal
USStudyCount
=
0
;
decimal
USStudyCount
=
0
;
if
(
firstModel
.
USStudyCount
>
0
&&
i
>
0
)
if
(
firstModel
.
USStudyCount
>
0
&&
i
>
0
)
{
{
USStudyCount
=
(
item
.
USStudyCount
-
firstModel
.
USStudyCount
)
/
firstModel
.
USStudyCount
*
100
;
USStudyCount
=
(
item
.
USStudyCount
-
firstModel
.
USStudyCount
)
/
firstModel
.
USStudyCount
*
100
;
}
}
decimal
SGStudyCount
=
0
;
decimal
SGStudyCount
=
0
;
if
(
firstModel
.
SGStudyCount
>
0
&&
i
>
0
)
if
(
firstModel
.
SGStudyCount
>
0
&&
i
>
0
)
{
{
SGStudyCount
=
(
item
.
SGStudyCount
-
firstModel
.
SGStudyCount
)
/
firstModel
.
SGStudyCount
*
100
;
SGStudyCount
=
(
item
.
SGStudyCount
-
firstModel
.
SGStudyCount
)
/
firstModel
.
SGStudyCount
*
100
;
}
}
decimal
AXStudyCount
=
0
;
decimal
AXStudyCount
=
0
;
if
(
firstModel
.
AXStudyCount
>
0
&&
i
>
0
)
if
(
firstModel
.
AXStudyCount
>
0
&&
i
>
0
)
{
{
AXStudyCount
=
(
item
.
AXStudyCount
-
firstModel
.
AXStudyCount
)
/
firstModel
.
AXStudyCount
*
100
;
AXStudyCount
=
(
item
.
AXStudyCount
-
firstModel
.
AXStudyCount
)
/
firstModel
.
AXStudyCount
*
100
;
}
}
decimal
OtherCount
=
0
;
decimal
OtherCount
=
0
;
if
(
firstModel
.
OtherCount
>
0
&&
i
>
0
)
if
(
firstModel
.
OtherCount
>
0
&&
i
>
0
)
{
{
OtherCount
=
(
item
.
OtherCount
-
firstModel
.
OtherCount
)
/
firstModel
.
OtherCount
*
100
;
OtherCount
=
(
item
.
OtherCount
-
firstModel
.
OtherCount
)
/
firstModel
.
OtherCount
*
100
;
}
}
decimal
ClassACount
=
0
;
decimal
ClassACount
=
0
;
if
(
firstModel
.
ClassACount
>
0
&&
i
>
0
)
if
(
firstModel
.
ClassACount
>
0
&&
i
>
0
)
{
{
ClassACount
=
(
item
.
ClassACount
-
firstModel
.
ClassACount
)
/
firstModel
.
ClassACount
*
100
;
ClassACount
=
(
item
.
ClassACount
-
firstModel
.
ClassACount
)
/
firstModel
.
ClassACount
*
100
;
}
}
decimal
ClassBCount
=
0
;
decimal
ClassBCount
=
0
;
if
(
firstModel
.
ClassBCount
>
0
&&
i
>
0
)
if
(
firstModel
.
ClassBCount
>
0
&&
i
>
0
)
{
{
ClassBCount
=
(
item
.
ClassBCount
-
firstModel
.
ClassBCount
)
/
firstModel
.
ClassBCount
*
100
;
ClassBCount
=
(
item
.
ClassBCount
-
firstModel
.
ClassBCount
)
/
firstModel
.
ClassBCount
*
100
;
}
}
decimal
ClassCCount
=
0
;
decimal
ClassCCount
=
0
;
if
(
firstModel
.
ClassCCount
>
0
)
if
(
firstModel
.
ClassCCount
>
0
)
{
{
ClassCCount
=
(
item
.
ClassCCount
-
firstModel
.
ClassCCount
)
/
firstModel
.
ClassCCount
*
100
;
ClassCCount
=
(
item
.
ClassCCount
-
firstModel
.
ClassCCount
)
/
firstModel
.
ClassCCount
*
100
;
}
}
decimal
ClassDCount
=
0
;
decimal
ClassDCount
=
0
;
if
(
firstModel
.
ClassDCount
>
0
&&
i
>
0
)
if
(
firstModel
.
ClassDCount
>
0
&&
i
>
0
)
{
{
ClassDCount
=
(
item
.
ClassDCount
-
firstModel
.
ClassDCount
)
/
firstModel
.
ClassDCount
*
100
;
ClassDCount
=
(
item
.
ClassDCount
-
firstModel
.
ClassDCount
)
/
firstModel
.
ClassDCount
*
100
;
}
}
decimal
CustomerCount
=
0
;
decimal
CustomerCount
=
0
;
if
(
firstModel
.
CustomerCount
>
0
&&
i
>
0
)
if
(
firstModel
.
CustomerCount
>
0
&&
i
>
0
)
{
{
CustomerCount
=
(
item
.
CustomerCount
-
firstModel
.
CustomerCount
)
/
firstModel
.
CustomerCount
*
100
;
CustomerCount
=
(
item
.
CustomerCount
-
firstModel
.
CustomerCount
)
/
firstModel
.
CustomerCount
*
100
;
}
}
decimal
B2CCount
=
0
;
decimal
B2CCount
=
0
;
if
(
firstModel
.
B2CCount
>
0
&&
i
>
0
)
if
(
firstModel
.
B2CCount
>
0
&&
i
>
0
)
{
{
B2CCount
=
(
item
.
B2CCount
-
firstModel
.
B2CCount
)
/
firstModel
.
B2CCount
*
100
;
B2CCount
=
(
item
.
B2CCount
-
firstModel
.
B2CCount
)
/
firstModel
.
B2CCount
*
100
;
}
}
decimal
TransCount
=
0
;
decimal
TransCount
=
0
;
if
(
firstModel
.
TransCount
>
0
&&
i
>
0
)
if
(
firstModel
.
TransCount
>
0
&&
i
>
0
)
{
{
TransCount
=
(
item
.
TransCount
-
firstModel
.
TransCount
)
/
firstModel
.
TransCount
*
100
;
TransCount
=
(
item
.
TransCount
-
firstModel
.
TransCount
)
/
firstModel
.
TransCount
*
100
;
}
}
decimal
InnerCount
=
0
;
decimal
InnerCount
=
0
;
if
(
firstModel
.
InnerCount
>
0
&&
i
>
0
)
if
(
firstModel
.
InnerCount
>
0
&&
i
>
0
)
{
{
InnerCount
=
(
item
.
InnerCount
-
firstModel
.
InnerCount
)
/
firstModel
.
InnerCount
*
100
;
InnerCount
=
(
item
.
InnerCount
-
firstModel
.
InnerCount
)
/
firstModel
.
InnerCount
*
100
;
}
}
decimal
InvalidCount
=
0
;
decimal
InvalidCount
=
0
;
if
(
item
.
InvalidCount
>
0
&&
i
>
0
)
if
(
item
.
InvalidCount
>
0
&&
i
>
0
)
{
{
InvalidCount
=
(
item
.
InvalidCount
-
firstModel
.
InvalidCount
)
/
item
.
InvalidCount
*
100
;
InvalidCount
=
(
item
.
InvalidCount
-
firstModel
.
InvalidCount
)
/
item
.
InvalidCount
*
100
;
}
}
decimal
SuspectedCount
=
0
;
decimal
SuspectedCount
=
0
;
if
(
firstModel
.
SuspectedCount
>
0
&&
i
>
0
)
if
(
firstModel
.
SuspectedCount
>
0
&&
i
>
0
)
{
{
SuspectedCount
=
(
item
.
SuspectedCount
-
firstModel
.
SuspectedCount
)
/
firstModel
.
SuspectedCount
*
100
;
SuspectedCount
=
(
item
.
SuspectedCount
-
firstModel
.
SuspectedCount
)
/
firstModel
.
SuspectedCount
*
100
;
}
}
decimal
IntentionCount
=
0
;
decimal
IntentionCount
=
0
;
if
(
firstModel
.
IntentionCount
>
0
&&
i
>
0
)
if
(
firstModel
.
IntentionCount
>
0
&&
i
>
0
)
{
{
IntentionCount
=
(
item
.
IntentionCount
-
firstModel
.
IntentionCount
)
/
firstModel
.
IntentionCount
*
100
;
IntentionCount
=
(
item
.
IntentionCount
-
firstModel
.
IntentionCount
)
/
firstModel
.
IntentionCount
*
100
;
}
}
decimal
InvitationCount
=
0
;
decimal
InvitationCount
=
0
;
if
(
firstModel
.
InvitationCount
>
0
&&
i
>
0
)
if
(
firstModel
.
InvitationCount
>
0
&&
i
>
0
)
{
{
InvitationCount
=
(
item
.
InvitationCount
-
firstModel
.
InvitationCount
)
/
firstModel
.
InvitationCount
*
100
;
InvitationCount
=
(
item
.
InvitationCount
-
firstModel
.
InvitationCount
)
/
firstModel
.
InvitationCount
*
100
;
}
}
decimal
NegotiationCount
=
0
;
decimal
NegotiationCount
=
0
;
if
(
firstModel
.
NegotiationCount
>
0
&&
i
>
0
)
if
(
firstModel
.
NegotiationCount
>
0
&&
i
>
0
)
{
{
NegotiationCount
=
(
item
.
NegotiationCount
-
firstModel
.
NegotiationCount
)
/
firstModel
.
NegotiationCount
*
100
;
NegotiationCount
=
(
item
.
NegotiationCount
-
firstModel
.
NegotiationCount
)
/
firstModel
.
NegotiationCount
*
100
;
}
}
decimal
ContractCount
=
0
;
decimal
ContractCount
=
0
;
if
(
firstModel
.
ContractCount
>
0
&&
i
>
0
)
if
(
firstModel
.
ContractCount
>
0
&&
i
>
0
)
{
{
ContractCount
=
(
item
.
ContractCount
-
firstModel
.
ContractCount
)
/
firstModel
.
ContractCount
*
100
;
ContractCount
=
(
item
.
ContractCount
-
firstModel
.
ContractCount
)
/
firstModel
.
ContractCount
*
100
;
}
}
decimal
OrderMoney
=
0
;
decimal
OrderMoney
=
0
;
if
(
firstModel
.
OrderMoney
>
0
&&
i
>
0
)
if
(
firstModel
.
OrderMoney
>
0
&&
i
>
0
)
{
{
OrderMoney
=
(
item
.
OrderMoney
-
firstModel
.
OrderMoney
)
/
firstModel
.
OrderMoney
*
100
;
OrderMoney
=
(
item
.
OrderMoney
-
firstModel
.
OrderMoney
)
/
firstModel
.
OrderMoney
*
100
;
}
}
decimal
StudyOrderMoney
=
0
;
decimal
StudyOrderMoney
=
0
;
if
(
firstModel
.
StudyOrderMoney
>
0
&&
i
>
0
)
if
(
firstModel
.
StudyOrderMoney
>
0
&&
i
>
0
)
{
{
StudyOrderMoney
=
(
item
.
StudyOrderMoney
-
firstModel
.
StudyOrderMoney
)
/
firstModel
.
StudyOrderMoney
*
100
;
StudyOrderMoney
=
(
item
.
StudyOrderMoney
-
firstModel
.
StudyOrderMoney
)
/
firstModel
.
StudyOrderMoney
*
100
;
}
var
newModel
=
new
RB_Student_Static_Extend
()
{
YearStr
=
minYear
+
y
,
MonthStr
=
i
+
1
,
PushCount
=
PushCount
,
NewCount
=
NewCount
,
CommunicationCount
=
CommunicationCount
,
TrialLessonCount
=
TrialLessonCount
,
NotContacted
=
NotContacted
,
JPCount
=
JPCount
,
KRCount
=
KRCount
,
FRCount
=
FRCount
,
JPStudyCount
=
JPStudyCount
,
KRStudyCount
=
KRStudyCount
,
YGAStudyCount
=
YGAStudyCount
,
USStudyCount
=
USStudyCount
,
SGStudyCount
=
SGStudyCount
,
AXStudyCount
=
AXStudyCount
,
OtherCount
=
OtherCount
,
ClassACount
=
ClassACount
,
ClassBCount
=
ClassBCount
,
ClassCCount
=
ClassCCount
,
ClassDCount
=
ClassDCount
,
CustomerCount
=
CustomerCount
,
B2CCount
=
B2CCount
,
TransCount
=
TransCount
,
InnerCount
=
InnerCount
,
InvalidCount
=
InvalidCount
,
SuspectedCount
=
SuspectedCount
,
IntentionCount
=
IntentionCount
,
InvitationCount
=
InvitationCount
,
NegotiationCount
=
NegotiationCount
,
ContractCount
=
ContractCount
,
OrderMoney
=
OrderMoney
,
StudyOrderMoney
=
StudyOrderMoney
,
};
result
.
Add
(
newModel
);
}
}
var
newModel
=
new
RB_Student_Static_Extend
()
{
YearStr
=
minYear
+
y
,
MonthStr
=
i
+
1
,
PushCount
=
PushCount
,
NewCount
=
NewCount
,
CommunicationCount
=
CommunicationCount
,
TrialLessonCount
=
TrialLessonCount
,
NotContacted
=
NotContacted
,
JPCount
=
JPCount
,
KRCount
=
KRCount
,
FRCount
=
FRCount
,
JPStudyCount
=
JPStudyCount
,
KRStudyCount
=
KRStudyCount
,
YGAStudyCount
=
YGAStudyCount
,
USStudyCount
=
USStudyCount
,
SGStudyCount
=
SGStudyCount
,
AXStudyCount
=
AXStudyCount
,
OtherCount
=
OtherCount
,
ClassACount
=
ClassACount
,
ClassBCount
=
ClassBCount
,
ClassCCount
=
ClassCCount
,
ClassDCount
=
ClassDCount
,
CustomerCount
=
CustomerCount
,
B2CCount
=
B2CCount
,
TransCount
=
TransCount
,
InnerCount
=
InnerCount
,
InvalidCount
=
InvalidCount
,
SuspectedCount
=
SuspectedCount
,
IntentionCount
=
IntentionCount
,
InvitationCount
=
InvitationCount
,
NegotiationCount
=
NegotiationCount
,
ContractCount
=
ContractCount
,
OrderMoney
=
OrderMoney
,
StudyOrderMoney
=
StudyOrderMoney
,
};
result
.
Add
(
newModel
);
}
}
}
var
lastPushCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
PushCount
);
var
lastPushCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
PushCount
);
var
curPushCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
PushCount
);
var
curPushCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
PushCount
);
decimal
CPushCount
=
0
;
decimal
CPushCount
=
0
;
if
(
lastPushCount
>
0
)
if
(
lastPushCount
>
0
)
{
{
CPushCount
=
(
curPushCount
-
lastPushCount
)
/
lastPushCount
*
100
;
CPushCount
=
(
curPushCount
-
lastPushCount
)
/
lastPushCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"推送人数成长率"
,
ItemName
=
"推送人数成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastPushCount
,
2
),
FirstYear
=
Math
.
Round
(
lastPushCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curPushCount
,
2
),
SecondYear
=
Math
.
Round
(
curPushCount
,
2
),
YearRate
=
Math
.
Round
(
CPushCount
,
2
),
YearRate
=
Math
.
Round
(
CPushCount
,
2
),
});
});
var
lastNewCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
NewCount
);
var
lastNewCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
NewCount
);
var
curNewCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
NewCount
);
var
curNewCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
NewCount
);
decimal
CNewCount
=
0
;
decimal
CNewCount
=
0
;
if
(
lastNewCount
>
0
)
if
(
lastNewCount
>
0
)
{
{
CNewCount
=
(
curNewCount
-
lastNewCount
)
/
lastNewCount
*
100
;
CNewCount
=
(
curNewCount
-
lastNewCount
)
/
lastNewCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"新客户成长率"
,
ItemName
=
"新客户成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastNewCount
,
2
),
FirstYear
=
Math
.
Round
(
lastNewCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curNewCount
,
2
),
SecondYear
=
Math
.
Round
(
curNewCount
,
2
),
YearRate
=
Math
.
Round
(
CNewCount
,
2
),
YearRate
=
Math
.
Round
(
CNewCount
,
2
),
});
});
var
lastCommunicationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
CommunicationCount
);
var
lastCommunicationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
CommunicationCount
);
var
curCommunicationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
CommunicationCount
);
var
curCommunicationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
CommunicationCount
);
decimal
CCommunicationCount
=
0
;
decimal
CCommunicationCount
=
0
;
if
(
lastCommunicationCount
>
0
)
if
(
lastCommunicationCount
>
0
)
{
{
CCommunicationCount
=
(
curCommunicationCount
-
lastCommunicationCount
)
/
lastCommunicationCount
*
100
;
CCommunicationCount
=
(
curCommunicationCount
-
lastCommunicationCount
)
/
lastCommunicationCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"初步(二次)沟通成长率"
,
ItemName
=
"初步(二次)沟通成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastCommunicationCount
,
2
),
FirstYear
=
Math
.
Round
(
lastCommunicationCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curCommunicationCount
,
2
),
SecondYear
=
Math
.
Round
(
curCommunicationCount
,
2
),
YearRate
=
Math
.
Round
(
CCommunicationCount
,
2
),
YearRate
=
Math
.
Round
(
CCommunicationCount
,
2
),
});
});
var
lastTrialLessonCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
TrialLessonCount
);
var
lastTrialLessonCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
TrialLessonCount
);
var
curTrialLessonCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
TrialLessonCount
);
var
curTrialLessonCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
TrialLessonCount
);
decimal
CTrialLessonCount
=
0
;
decimal
CTrialLessonCount
=
0
;
if
(
lastTrialLessonCount
>
0
)
if
(
lastTrialLessonCount
>
0
)
{
{
CTrialLessonCount
=
(
curTrialLessonCount
-
lastTrialLessonCount
)
/
lastTrialLessonCount
*
100
;
CTrialLessonCount
=
(
curTrialLessonCount
-
lastTrialLessonCount
)
/
lastTrialLessonCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"预约试听(已到店.已试听)成长率"
,
ItemName
=
"预约试听(已到店.已试听)成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastTrialLessonCount
,
2
),
FirstYear
=
Math
.
Round
(
lastTrialLessonCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curTrialLessonCount
,
2
),
SecondYear
=
Math
.
Round
(
curTrialLessonCount
,
2
),
YearRate
=
Math
.
Round
(
CTrialLessonCount
,
2
),
YearRate
=
Math
.
Round
(
CTrialLessonCount
,
2
),
});
});
var
lastNotContacted
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
NotContacted
);
var
lastNotContacted
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
NotContacted
);
var
curNotContacted
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
NotContacted
);
var
curNotContacted
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
NotContacted
);
decimal
CNotContacted
=
0
;
decimal
CNotContacted
=
0
;
if
(
lastNotContacted
>
0
)
if
(
lastNotContacted
>
0
)
{
{
CNotContacted
=
(
curNotContacted
-
lastNotContacted
)
/
lastNotContacted
*
100
;
CNotContacted
=
(
curNotContacted
-
lastNotContacted
)
/
lastNotContacted
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"待联系成长率"
,
ItemName
=
"待联系成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastNotContacted
,
2
),
FirstYear
=
Math
.
Round
(
lastNotContacted
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curNotContacted
,
2
),
SecondYear
=
Math
.
Round
(
curNotContacted
,
2
),
YearRate
=
Math
.
Round
(
CNotContacted
,
2
),
YearRate
=
Math
.
Round
(
CNotContacted
,
2
),
});
});
var
lastJPCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
JPCount
);
var
lastJPCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
JPCount
);
var
curJPCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
JPCount
);
var
curJPCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
JPCount
);
decimal
CJPCount
=
0
;
decimal
CJPCount
=
0
;
if
(
lastJPCount
>
0
)
if
(
lastJPCount
>
0
)
{
{
CJPCount
=
(
curJPCount
-
lastJPCount
)
/
lastJPCount
*
100
;
CJPCount
=
(
curJPCount
-
lastJPCount
)
/
lastJPCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"日本语培成长率"
,
ItemName
=
"日本语培成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastJPCount
,
2
),
FirstYear
=
Math
.
Round
(
lastJPCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curJPCount
,
2
),
SecondYear
=
Math
.
Round
(
curJPCount
,
2
),
YearRate
=
Math
.
Round
(
CJPCount
,
2
),
YearRate
=
Math
.
Round
(
CJPCount
,
2
),
});
});
var
lastKRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
KRCount
);
var
lastKRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
KRCount
);
var
curKRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
KRCount
);
var
curKRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
KRCount
);
decimal
CKRCount
=
0
;
decimal
CKRCount
=
0
;
if
(
lastKRCount
>
0
)
if
(
lastKRCount
>
0
)
{
{
CKRCount
=
(
curKRCount
-
lastKRCount
)
/
lastKRCount
*
100
;
CKRCount
=
(
curKRCount
-
lastKRCount
)
/
lastKRCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"韩国语培成长率"
,
ItemName
=
"韩国语培成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastKRCount
,
2
),
FirstYear
=
Math
.
Round
(
lastKRCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curKRCount
,
2
),
SecondYear
=
Math
.
Round
(
curKRCount
,
2
),
YearRate
=
Math
.
Round
(
CKRCount
,
2
),
YearRate
=
Math
.
Round
(
CKRCount
,
2
),
});
});
var
lastFRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
FRCount
);
var
lastFRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
FRCount
);
var
curFRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
FRCount
);
var
curFRCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
FRCount
);
decimal
CFRCount
=
0
;
decimal
CFRCount
=
0
;
if
(
lastFRCount
>
0
)
if
(
lastFRCount
>
0
)
{
{
CFRCount
=
(
curFRCount
-
lastFRCount
)
/
lastFRCount
*
100
;
CFRCount
=
(
curFRCount
-
lastFRCount
)
/
lastFRCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"法国语培成长率"
,
ItemName
=
"法国语培成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastFRCount
,
2
),
FirstYear
=
Math
.
Round
(
lastFRCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curFRCount
,
2
),
SecondYear
=
Math
.
Round
(
curFRCount
,
2
),
YearRate
=
Math
.
Round
(
CFRCount
,
2
),
YearRate
=
Math
.
Round
(
CFRCount
,
2
),
});
});
var
lastJPStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
JPStudyCount
);
var
lastJPStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
JPStudyCount
);
var
curJPStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
JPStudyCount
);
var
curJPStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
JPStudyCount
);
decimal
CJPStudyCount
=
0
;
decimal
CJPStudyCount
=
0
;
if
(
lastJPStudyCount
>
0
)
if
(
lastJPStudyCount
>
0
)
{
{
CJPStudyCount
=
(
curJPStudyCount
-
lastJPStudyCount
)
/
lastJPStudyCount
*
100
;
CJPStudyCount
=
(
curJPStudyCount
-
lastJPStudyCount
)
/
lastJPStudyCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"日本留学成长率"
,
ItemName
=
"日本留学成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastJPStudyCount
,
2
),
FirstYear
=
Math
.
Round
(
lastJPStudyCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curJPStudyCount
,
2
),
SecondYear
=
Math
.
Round
(
curJPStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CJPStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CJPStudyCount
,
2
),
});
});
var
lastKRStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
KRStudyCount
);
var
lastKRStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
KRStudyCount
);
var
curKRStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
KRStudyCount
);
var
curKRStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
KRStudyCount
);
decimal
CKRStudyCount
=
0
;
decimal
CKRStudyCount
=
0
;
if
(
lastKRStudyCount
>
0
)
if
(
lastKRStudyCount
>
0
)
{
{
CKRStudyCount
=
(
curKRStudyCount
-
lastKRStudyCount
)
/
lastKRStudyCount
*
100
;
CKRStudyCount
=
(
curKRStudyCount
-
lastKRStudyCount
)
/
lastKRStudyCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"韩国留学成长率"
,
ItemName
=
"韩国留学成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastKRStudyCount
,
2
),
FirstYear
=
Math
.
Round
(
lastKRStudyCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curKRStudyCount
,
2
),
SecondYear
=
Math
.
Round
(
curKRStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CKRStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CKRStudyCount
,
2
),
});
});
var
lastYGAStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
YGAStudyCount
);
var
lastYGAStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
YGAStudyCount
);
var
curYGAStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
YGAStudyCount
);
var
curYGAStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
YGAStudyCount
);
decimal
CYGAStudyCount
=
0
;
decimal
CYGAStudyCount
=
0
;
if
(
lastYGAStudyCount
>
0
)
if
(
lastYGAStudyCount
>
0
)
{
{
CYGAStudyCount
=
(
curYGAStudyCount
-
lastYGAStudyCount
)
/
lastYGAStudyCount
*
100
;
CYGAStudyCount
=
(
curYGAStudyCount
-
lastYGAStudyCount
)
/
lastYGAStudyCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"英港澳留学成长率"
,
ItemName
=
"英港澳留学成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastYGAStudyCount
,
2
),
FirstYear
=
Math
.
Round
(
lastYGAStudyCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curYGAStudyCount
,
2
),
SecondYear
=
Math
.
Round
(
curYGAStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CYGAStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CYGAStudyCount
,
2
),
});
});
var
lastUSStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
USStudyCount
);
var
lastUSStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
USStudyCount
);
var
curUSStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
USStudyCount
);
var
curUSStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
USStudyCount
);
decimal
CUSStudyCount
=
0
;
decimal
CUSStudyCount
=
0
;
if
(
lastUSStudyCount
>
0
)
if
(
lastUSStudyCount
>
0
)
{
{
CUSStudyCount
=
(
curUSStudyCount
-
lastUSStudyCount
)
/
lastUSStudyCount
*
100
;
CUSStudyCount
=
(
curUSStudyCount
-
lastUSStudyCount
)
/
lastUSStudyCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"美国留学成长率"
,
ItemName
=
"美国留学成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastUSStudyCount
,
2
),
FirstYear
=
Math
.
Round
(
lastUSStudyCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curUSStudyCount
,
2
),
SecondYear
=
Math
.
Round
(
curUSStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CUSStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CUSStudyCount
,
2
),
});
});
var
lastSGStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
SGStudyCount
);
var
lastSGStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
SGStudyCount
);
var
curSGStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
SGStudyCount
);
var
curSGStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
SGStudyCount
);
decimal
CSGStudyCount
=
0
;
decimal
CSGStudyCount
=
0
;
if
(
lastSGStudyCount
>
0
)
if
(
lastSGStudyCount
>
0
)
{
{
CSGStudyCount
=
(
curSGStudyCount
-
lastSGStudyCount
)
/
lastSGStudyCount
*
100
;
CSGStudyCount
=
(
curSGStudyCount
-
lastSGStudyCount
)
/
lastSGStudyCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"新加坡留学成长率"
,
ItemName
=
"新加坡留学成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastSGStudyCount
,
2
),
FirstYear
=
Math
.
Round
(
lastSGStudyCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curSGStudyCount
,
2
),
SecondYear
=
Math
.
Round
(
curSGStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CSGStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CSGStudyCount
,
2
),
});
});
var
lastAXStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
AXStudyCount
);
var
lastAXStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
AXStudyCount
);
var
curAXStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
AXStudyCount
);
var
curAXStudyCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
AXStudyCount
);
decimal
CAXStudyCount
=
0
;
decimal
CAXStudyCount
=
0
;
if
(
lastAXStudyCount
>
0
)
if
(
lastAXStudyCount
>
0
)
{
{
CAXStudyCount
=
(
curAXStudyCount
-
lastAXStudyCount
)
/
lastAXStudyCount
*
100
;
CAXStudyCount
=
(
curAXStudyCount
-
lastAXStudyCount
)
/
lastAXStudyCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"澳新留学成长率"
,
ItemName
=
"澳新留学成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastAXStudyCount
,
2
),
FirstYear
=
Math
.
Round
(
lastAXStudyCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curAXStudyCount
,
2
),
SecondYear
=
Math
.
Round
(
curAXStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CAXStudyCount
,
2
),
YearRate
=
Math
.
Round
(
CAXStudyCount
,
2
),
});
});
var
lastOtherCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
OtherCount
);
var
lastOtherCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
OtherCount
);
var
curOtherCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
OtherCount
);
var
curOtherCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
OtherCount
);
decimal
COtherCount
=
0
;
decimal
COtherCount
=
0
;
if
(
lastOtherCount
>
0
)
if
(
lastOtherCount
>
0
)
{
{
COtherCount
=
(
curOtherCount
-
lastOtherCount
)
/
lastOtherCount
*
100
;
COtherCount
=
(
curOtherCount
-
lastOtherCount
)
/
lastOtherCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"其他成长率"
,
ItemName
=
"其他成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastOtherCount
,
2
),
FirstYear
=
Math
.
Round
(
lastOtherCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curOtherCount
,
2
),
SecondYear
=
Math
.
Round
(
curOtherCount
,
2
),
YearRate
=
Math
.
Round
(
COtherCount
,
2
),
YearRate
=
Math
.
Round
(
COtherCount
,
2
),
});
});
var
lastClassACount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassACount
);
var
lastClassACount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassACount
);
var
curClassACount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassACount
);
var
curClassACount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassACount
);
decimal
CClassACount
=
0
;
decimal
CClassACount
=
0
;
if
(
lastClassACount
>
0
)
if
(
lastClassACount
>
0
)
{
{
CClassACount
=
(
curClassACount
-
lastClassACount
)
/
lastClassACount
*
100
;
CClassACount
=
(
curClassACount
-
lastClassACount
)
/
lastClassACount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"A类客户成长率"
,
ItemName
=
"A类客户成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastClassACount
,
2
),
FirstYear
=
Math
.
Round
(
lastClassACount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curClassACount
,
2
),
SecondYear
=
Math
.
Round
(
curClassACount
,
2
),
YearRate
=
Math
.
Round
(
CClassACount
,
2
),
YearRate
=
Math
.
Round
(
CClassACount
,
2
),
});
});
var
lastClassBCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassBCount
);
var
lastClassBCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassBCount
);
var
curClassBCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassBCount
);
var
curClassBCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassBCount
);
decimal
CClassBCount
=
0
;
decimal
CClassBCount
=
0
;
if
(
lastClassBCount
>
0
)
if
(
lastClassBCount
>
0
)
{
{
CClassBCount
=
(
curClassBCount
-
lastClassBCount
)
/
lastClassBCount
*
100
;
CClassBCount
=
(
curClassBCount
-
lastClassBCount
)
/
lastClassBCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"B类客户成长率"
,
ItemName
=
"B类客户成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastClassBCount
,
2
),
FirstYear
=
Math
.
Round
(
lastClassBCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curClassBCount
,
2
),
SecondYear
=
Math
.
Round
(
curClassBCount
,
2
),
YearRate
=
Math
.
Round
(
CClassBCount
,
2
),
YearRate
=
Math
.
Round
(
CClassBCount
,
2
),
});
});
var
lastClassCCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassCCount
);
var
lastClassCCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassCCount
);
var
curClassCCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassCCount
);
var
curClassCCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassCCount
);
decimal
CClassCCount
=
0
;
decimal
CClassCCount
=
0
;
if
(
lastClassCCount
>
0
)
if
(
lastClassCCount
>
0
)
{
{
CClassCCount
=
(
curClassCCount
-
lastClassCCount
)
/
lastClassCCount
*
100
;
CClassCCount
=
(
curClassCCount
-
lastClassCCount
)
/
lastClassCCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"C类客户成长率"
,
ItemName
=
"C类客户成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastClassCCount
,
2
),
FirstYear
=
Math
.
Round
(
lastClassCCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curClassCCount
,
2
),
SecondYear
=
Math
.
Round
(
curClassCCount
,
2
),
YearRate
=
Math
.
Round
(
CClassCCount
,
2
),
YearRate
=
Math
.
Round
(
CClassCCount
,
2
),
});
});
var
lastClassDCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassDCount
);
var
lastClassDCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ClassDCount
);
var
curClassDCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassDCount
);
var
curClassDCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ClassDCount
);
decimal
CClassDCount
=
0
;
decimal
CClassDCount
=
0
;
if
(
lastClassDCount
>
0
)
if
(
lastClassDCount
>
0
)
{
{
CClassDCount
=
(
curClassDCount
-
lastClassDCount
)
/
lastClassDCount
*
100
;
CClassDCount
=
(
curClassDCount
-
lastClassDCount
)
/
lastClassDCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"D类客户成长率"
,
ItemName
=
"D类客户成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastClassDCount
,
2
),
FirstYear
=
Math
.
Round
(
lastClassDCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curClassDCount
,
2
),
SecondYear
=
Math
.
Round
(
curClassDCount
,
2
),
YearRate
=
Math
.
Round
(
CClassDCount
,
2
),
YearRate
=
Math
.
Round
(
CClassDCount
,
2
),
});
});
var
lastCustomerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
CustomerCount
);
var
lastCustomerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
CustomerCount
);
var
curCustomerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
CustomerCount
);
var
curCustomerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
CustomerCount
);
decimal
CCustomerCount
=
0
;
decimal
CCustomerCount
=
0
;
if
(
lastCustomerCount
>
0
)
if
(
lastCustomerCount
>
0
)
{
{
CCustomerCount
=
(
curCustomerCount
-
lastCustomerCount
)
/
lastCustomerCount
*
100
;
CCustomerCount
=
(
curCustomerCount
-
lastCustomerCount
)
/
lastCustomerCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"同行介绍成长率"
,
ItemName
=
"同行介绍成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastCustomerCount
,
2
),
FirstYear
=
Math
.
Round
(
lastCustomerCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curCustomerCount
,
2
),
SecondYear
=
Math
.
Round
(
curCustomerCount
,
2
),
YearRate
=
Math
.
Round
(
CCustomerCount
,
2
),
YearRate
=
Math
.
Round
(
CCustomerCount
,
2
),
});
});
var
lastB2CCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
B2CCount
);
var
lastB2CCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
B2CCount
);
var
curB2CCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
B2CCount
);
var
curB2CCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
B2CCount
);
decimal
CB2CCount
=
0
;
decimal
CB2CCount
=
0
;
if
(
lastB2CCount
>
0
)
if
(
lastB2CCount
>
0
)
{
{
CB2CCount
=
(
curB2CCount
-
lastB2CCount
)
/
lastB2CCount
*
100
;
CB2CCount
=
(
curB2CCount
-
lastB2CCount
)
/
lastB2CCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"直客成长率"
,
ItemName
=
"直客成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastB2CCount
,
2
),
FirstYear
=
Math
.
Round
(
lastB2CCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curB2CCount
,
2
),
SecondYear
=
Math
.
Round
(
curB2CCount
,
2
),
YearRate
=
Math
.
Round
(
CB2CCount
,
2
),
YearRate
=
Math
.
Round
(
CB2CCount
,
2
),
});
});
var
lastTransCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
TransCount
);
var
lastTransCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
TransCount
);
var
curTransCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
TransCount
);
var
curTransCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
TransCount
);
decimal
CTransCount
=
0
;
decimal
CTransCount
=
0
;
if
(
lastTransCount
>
0
)
if
(
lastTransCount
>
0
)
{
{
CTransCount
=
(
curTransCount
-
lastTransCount
)
/
lastTransCount
*
100
;
CTransCount
=
(
curTransCount
-
lastTransCount
)
/
lastTransCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"学员转介绍成长率"
,
ItemName
=
"学员转介绍成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastTransCount
,
2
),
FirstYear
=
Math
.
Round
(
lastTransCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curTransCount
,
2
),
SecondYear
=
Math
.
Round
(
curTransCount
,
2
),
YearRate
=
Math
.
Round
(
CTransCount
,
2
),
YearRate
=
Math
.
Round
(
CTransCount
,
2
),
});
});
var
lastInnerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
InnerCount
);
var
lastInnerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
InnerCount
);
var
curInnerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
InnerCount
);
var
curInnerCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
InnerCount
);
decimal
CInnerCount
=
0
;
decimal
CInnerCount
=
0
;
if
(
lastInnerCount
>
0
)
if
(
lastInnerCount
>
0
)
{
{
CInnerCount
=
(
curInnerCount
-
lastInnerCount
)
/
lastInnerCount
*
100
;
CInnerCount
=
(
curInnerCount
-
lastInnerCount
)
/
lastInnerCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"内部介绍成长率"
,
ItemName
=
"内部介绍成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastInnerCount
,
2
),
FirstYear
=
Math
.
Round
(
lastInnerCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curInnerCount
,
2
),
SecondYear
=
Math
.
Round
(
curInnerCount
,
2
),
YearRate
=
Math
.
Round
(
CInnerCount
,
2
),
YearRate
=
Math
.
Round
(
CInnerCount
,
2
),
});
});
var
lastInvalidCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
InvalidCount
);
var
lastInvalidCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
InvalidCount
);
var
curInvalidCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
InvalidCount
);
var
curInvalidCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
InvalidCount
);
decimal
CInvalidCount
=
0
;
decimal
CInvalidCount
=
0
;
if
(
lastInvalidCount
>
0
)
if
(
lastInvalidCount
>
0
)
{
{
CInvalidCount
=
(
curInvalidCount
-
lastInvalidCount
)
/
lastInvalidCount
*
100
;
CInvalidCount
=
(
curInvalidCount
-
lastInvalidCount
)
/
lastInvalidCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"无效成长率"
,
ItemName
=
"无效成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastInvalidCount
,
2
),
FirstYear
=
Math
.
Round
(
lastInvalidCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curInvalidCount
,
2
),
SecondYear
=
Math
.
Round
(
curInvalidCount
,
2
),
YearRate
=
Math
.
Round
(
CInvalidCount
,
2
),
YearRate
=
Math
.
Round
(
CInvalidCount
,
2
),
});
});
var
lastSuspectedCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
SuspectedCount
);
var
lastSuspectedCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
SuspectedCount
);
var
curSuspectedCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
SuspectedCount
);
var
curSuspectedCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
SuspectedCount
);
decimal
CSuspectedCount
=
0
;
decimal
CSuspectedCount
=
0
;
if
(
lastSuspectedCount
>
0
)
if
(
lastSuspectedCount
>
0
)
{
{
CSuspectedCount
=
(
curSuspectedCount
-
lastSuspectedCount
)
/
lastSuspectedCount
*
100
;
CSuspectedCount
=
(
curSuspectedCount
-
lastSuspectedCount
)
/
lastSuspectedCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"疑似成长率"
,
ItemName
=
"疑似成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastSuspectedCount
,
2
),
FirstYear
=
Math
.
Round
(
lastSuspectedCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curSuspectedCount
,
2
),
SecondYear
=
Math
.
Round
(
curSuspectedCount
,
2
),
YearRate
=
Math
.
Round
(
CSuspectedCount
,
2
),
YearRate
=
Math
.
Round
(
CSuspectedCount
,
2
),
});
});
var
lastIntentionCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
IntentionCount
);
var
lastIntentionCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
IntentionCount
);
var
curIntentionCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
IntentionCount
);
var
curIntentionCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
IntentionCount
);
decimal
CIntentionCount
=
0
;
decimal
CIntentionCount
=
0
;
if
(
lastIntentionCount
>
0
)
if
(
lastIntentionCount
>
0
)
{
{
CIntentionCount
=
(
curIntentionCount
-
lastIntentionCount
)
/
lastIntentionCount
*
100
;
CIntentionCount
=
(
curIntentionCount
-
lastIntentionCount
)
/
lastIntentionCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"意向成长率"
,
ItemName
=
"意向成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastIntentionCount
,
2
),
FirstYear
=
Math
.
Round
(
lastIntentionCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curIntentionCount
,
2
),
SecondYear
=
Math
.
Round
(
curIntentionCount
,
2
),
YearRate
=
Math
.
Round
(
CIntentionCount
,
2
),
YearRate
=
Math
.
Round
(
CIntentionCount
,
2
),
});
});
var
lastInvitationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
InvitationCount
);
var
lastInvitationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
InvitationCount
);
var
curInvitationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
InvitationCount
);
var
curInvitationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
InvitationCount
);
decimal
CInvitationCount
=
0
;
decimal
CInvitationCount
=
0
;
if
(
lastInvitationCount
>
0
)
if
(
lastInvitationCount
>
0
)
{
{
CInvitationCount
=
(
curInvitationCount
-
lastInvitationCount
)
/
lastInvitationCount
*
100
;
CInvitationCount
=
(
curInvitationCount
-
lastInvitationCount
)
/
lastInvitationCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"近期课邀约成长率"
,
ItemName
=
"近期课邀约成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastInvitationCount
,
2
),
FirstYear
=
Math
.
Round
(
lastInvitationCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curInvitationCount
,
2
),
SecondYear
=
Math
.
Round
(
curInvitationCount
,
2
),
YearRate
=
Math
.
Round
(
CInvitationCount
,
2
),
YearRate
=
Math
.
Round
(
CInvitationCount
,
2
),
});
});
var
lastNegotiationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
NegotiationCount
);
var
lastNegotiationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
NegotiationCount
);
var
curNegotiationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
NegotiationCount
);
var
curNegotiationCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
NegotiationCount
);
decimal
CNegotiationCount
=
0
;
decimal
CNegotiationCount
=
0
;
if
(
lastNegotiationCount
>
0
)
if
(
lastNegotiationCount
>
0
)
{
{
CNegotiationCount
=
(
curNegotiationCount
-
lastNegotiationCount
)
/
lastNegotiationCount
*
100
;
CNegotiationCount
=
(
curNegotiationCount
-
lastNegotiationCount
)
/
lastNegotiationCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"谈判成长率"
,
ItemName
=
"谈判成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastNegotiationCount
,
2
),
FirstYear
=
Math
.
Round
(
lastNegotiationCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curNegotiationCount
,
2
),
SecondYear
=
Math
.
Round
(
curNegotiationCount
,
2
),
YearRate
=
Math
.
Round
(
CNegotiationCount
,
2
),
YearRate
=
Math
.
Round
(
CNegotiationCount
,
2
),
});
});
var
lastContractCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ContractCount
);
var
lastContractCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
ContractCount
);
var
curContractCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ContractCount
);
var
curContractCount
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
ContractCount
);
decimal
CContractCount
=
0
;
decimal
CContractCount
=
0
;
if
(
lastContractCount
>
0
)
if
(
lastContractCount
>
0
)
{
{
CContractCount
=
(
curContractCount
-
lastContractCount
)
/
lastContractCount
*
100
;
CContractCount
=
(
curContractCount
-
lastContractCount
)
/
lastContractCount
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"签约.成交.续费成长率"
,
ItemName
=
"签约.成交.续费成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastContractCount
,
2
),
FirstYear
=
Math
.
Round
(
lastContractCount
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curContractCount
,
2
),
SecondYear
=
Math
.
Round
(
curContractCount
,
2
),
YearRate
=
Math
.
Round
(
CContractCount
,
2
),
YearRate
=
Math
.
Round
(
CContractCount
,
2
),
});
});
var
lastOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
OrderMoney
);
var
lastOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
OrderMoney
);
var
curOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
OrderMoney
);
var
curOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
OrderMoney
);
decimal
COrderMoney
=
0
;
decimal
COrderMoney
=
0
;
if
(
lastOrderMoney
>
0
)
if
(
lastOrderMoney
>
0
)
{
{
COrderMoney
=
(
curOrderMoney
-
lastOrderMoney
)
/
lastOrderMoney
*
100
;
COrderMoney
=
(
curOrderMoney
-
lastOrderMoney
)
/
lastOrderMoney
*
100
;
}
}
yearList
.
Add
(
new
RateYearItem
()
yearList
.
Add
(
new
RateYearItem
()
{
{
ItemName
=
"语培签约金额成长率"
,
ItemName
=
"语培签约金额成长率"
,
FirstYearStr
=
minYear
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastOrderMoney
,
2
),
FirstYear
=
Math
.
Round
(
lastOrderMoney
,
2
),
SecondYearStr
=
maxYear
,
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curOrderMoney
,
2
),
SecondYear
=
Math
.
Round
(
curOrderMoney
,
2
),
YearRate
=
Math
.
Round
(
COrderMoney
,
2
),
YearRate
=
Math
.
Round
(
COrderMoney
,
2
),
});
});
var
lastStudyOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
StudyOrderMoney
);
var
lastStudyOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
minYear
).
Average
(
qitem
=>
qitem
.
StudyOrderMoney
);
var
curStudyOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
StudyOrderMoney
);
var
curStudyOrderMoney
=
result
.
Where
(
qitem
=>
qitem
.
YearStr
==
maxYear
).
Average
(
qitem
=>
qitem
.
StudyOrderMoney
);
decimal
CStudyOrderMoney
=
0
;
decimal
CStudyOrderMoney
=
0
;
if
(
lastStudyOrderMoney
>
0
)
if
(
lastStudyOrderMoney
>
0
)
{
{
CStudyOrderMoney
=
(
curStudyOrderMoney
-
lastStudyOrderMoney
)
/
lastStudyOrderMoney
*
100
;
CStudyOrderMoney
=
(
curStudyOrderMoney
-
lastStudyOrderMoney
)
/
lastStudyOrderMoney
*
100
;
}
yearList
.
Add
(
new
RateYearItem
()
{
ItemName
=
"留学签约金额成长率"
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastStudyOrderMoney
,
2
),
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curStudyOrderMoney
,
2
),
YearRate
=
Math
.
Round
(
CStudyOrderMoney
,
2
),
});
}
}
yearList
.
Add
(
new
RateYearItem
()
{
ItemName
=
"留学签约金额成长率"
,
FirstYearStr
=
minYear
,
FirstYear
=
Math
.
Round
(
lastStudyOrderMoney
,
2
),
SecondYearStr
=
maxYear
,
SecondYear
=
Math
.
Round
(
curStudyOrderMoney
,
2
),
YearRate
=
Math
.
Round
(
CStudyOrderMoney
,
2
),
});
return
yearList
;
return
yearList
;
}
}
...
...
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