Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
performance
Overview
Overview
Details
Activity
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
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
zry
performance
Commits
237dfe08
Commit
237dfe08
authored
Jan 26, 2021
by
lcx
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
4.1数据写入
parent
8bb620c0
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
46 additions
and
12 deletions
+46
-12
performance/Performance.Services/ExtractExcelService/ExtractHelper/ExcelHelper.cs
+1
-5
performance/Performance.Services/ExtractExcelService/ExtractService.cs
+4
-2
performance/Performance.Services/ExtractExcelService/SheetDataWrite/AccountBasicDataWrite.cs
+37
-2
performance/Performance.Services/ExtractExcelService/WriteDataFactory.cs
+3
-3
performance/Performance.Services/PerExcelService/SheetDataRead/PerSheetDataReadDeptAccounting.cs
+1
-0
No files found.
performance/Performance.Services/ExtractExcelService/ExtractHelper/ExcelHelper.cs
View file @
237dfe08
...
@@ -203,11 +203,7 @@ public static string GetDecodeEscapes(this ICell cell)
...
@@ -203,11 +203,7 @@ public static string GetDecodeEscapes(this ICell cell)
if
(
cell
==
null
)
return
""
;
if
(
cell
==
null
)
return
""
;
cell
.
SetCellType
(
CellType
.
String
);
cell
.
SetCellType
(
CellType
.
String
);
string
value
=
cell
.
StringCellValue
;
return
cell
.
StringCellValue
.
NoBlank
();
if
(!
string
.
IsNullOrEmpty
(
value
))
value
=
value
.
Replace
(
"\n"
,
""
).
Replace
(
"\r"
,
""
).
Replace
(
" "
,
""
).
Trim
();
return
value
;
}
}
catch
catch
{
{
...
...
performance/Performance.Services/ExtractExcelService/ExtractService.cs
View file @
237dfe08
...
@@ -136,7 +136,7 @@ private void WriteDataToFile(IWorkbook workbook, int allotId, Dictionary<ExDataD
...
@@ -136,7 +136,7 @@ private void WriteDataToFile(IWorkbook workbook, int allotId, Dictionary<ExDataD
logger
.
LogInformation
(
$"allotId:
{
allotId
}
: 总金额 -
{
extractDto
?.
Sum
(
s
=>
s
.
Value
??
0
)}
"
);
logger
.
LogInformation
(
$"allotId:
{
allotId
}
: 总金额 -
{
extractDto
?.
Sum
(
s
=>
s
.
Value
??
0
)}
"
);
WriteDataFactory
factory
=
new
WriteDataFactory
();
WriteDataFactory
factory
=
new
WriteDataFactory
();
var
types
=
new
List
<
SheetType
>
{
SheetType
.
OtherIncome
,
SheetType
.
Income
,
SheetType
.
Expend
,
SheetType
.
Workload
,
SheetType
.
OtherWorkload
};
var
types
=
new
List
<
SheetType
>
{
SheetType
.
OtherIncome
,
SheetType
.
Income
,
SheetType
.
Expend
,
SheetType
.
Workload
,
SheetType
.
OtherWorkload
,
SheetType
.
AccountBasic
};
decimal
ratio
=
60
m
;
decimal
ratio
=
60
m
;
for
(
int
sheetIndex
=
0
;
sheetIndex
<
workbook
.
NumberOfSheets
;
sheetIndex
++)
for
(
int
sheetIndex
=
0
;
sheetIndex
<
workbook
.
NumberOfSheets
;
sheetIndex
++)
{
{
...
@@ -182,9 +182,11 @@ private object GetDataBySheetType(SheetType sheetType, List<ExtractTransDto> ext
...
@@ -182,9 +182,11 @@ private object GetDataBySheetType(SheetType sheetType, List<ExtractTransDto> ext
{
{
case
SheetType
.
Employee
:
case
SheetType
.
Employee
:
case
SheetType
.
ClinicEmployee
:
case
SheetType
.
ClinicEmployee
:
case
SheetType
.
AccountBasic
:
return
employeeDict
;
return
employeeDict
;
case
SheetType
.
AccountBasic
:
return
new
List
<
im_accountbasic
>();
default
:
default
:
return
extractDto
;
return
extractDto
;
}
}
...
...
performance/Performance.Services/ExtractExcelService/SheetDataWrite/AccountBasicDataWrite.cs
View file @
237dfe08
...
@@ -3,20 +3,55 @@
...
@@ -3,20 +3,55 @@
using
Performance.EntityModels
;
using
Performance.EntityModels
;
using
System
;
using
System
;
using
System.Collections.Generic
;
using
System.Collections.Generic
;
using
System.Linq
;
using
System.Text
;
using
System.Text
;
namespace
Performance.Services.ExtractExcelService.SheetDataWrite
namespace
Performance.Services.ExtractExcelService.SheetDataWrite
{
{
class
AccountBasicDataWrite
:
ISheetDataWrite
internal
class
AccountBasicDataWrite
:
ISheetDataWrite
{
{
public
void
WriteCollectData
(
ISheet
sheet
,
PerSheetPoint
point
,
SheetType
sheetType
,
ExcelStyle
style
,
List
<
collect_data
>
collects
)
public
void
WriteCollectData
(
ISheet
sheet
,
PerSheetPoint
point
,
SheetType
sheetType
,
ExcelStyle
style
,
List
<
collect_data
>
collects
)
{
{
if
(
collects
==
null
||
!
collects
.
Any
(
t
=>
!
string
.
IsNullOrEmpty
(
t
.
TypeName
)))
return
;
var
headerRow
=
sheet
.
GetRow
(
point
.
HeaderFirstRowNum
??
1
);
var
columns
=
headerRow
.
GetCellValues
();
if
(
columns
==
null
||
!
columns
.
Any
())
return
;
collects
.
ForEach
(
t
=>
{
t
.
UnitType
=
t
.
UnitType
.
NoBlank
();
t
.
AccountingUnitDoctor
=
t
.
AccountingUnitDoctor
.
NoBlank
();
t
.
TypeName
=
t
.
TypeName
.
NoBlank
();
});
var
rownumbers
=
collects
.
Select
(
t
=>
t
.
RowNumber
).
Distinct
().
OrderBy
(
t
=>
t
).
ToList
();
for
(
int
i
=
point
.
DataFirstRowNum
.
Value
;
i
<
sheet
.
LastRowNum
+
1
;
i
++)
{
var
row
=
sheet
.
GetRow
(
i
);
if
(
row
!=
null
)
{
string
unittype
=
row
.
GetCell
(
point
.
DataFirstCellNum
.
Value
-
2
).
GetDecodeEscapes
();
string
accountingunit
=
row
.
GetCell
(
point
.
DataFirstCellNum
.
Value
-
1
).
GetDecodeEscapes
();
int
cellIndex
=
point
.
DataFirstCellNum
.
Value
;
foreach
(
var
column
in
columns
)
{
var
data
=
collects
.
FirstOrDefault
(
t
=>
t
.
UnitType
==
unittype
&&
t
.
AccountingUnitDoctor
==
accountingunit
&&
t
.
TypeName
==
column
);
if
(
data
!=
null
)
{
var
cell
=
row
.
GetCell
(
cellIndex
);
if
(
cell
!=
null
)
cell
.
SetCellValue
<
decimal
>(
data
.
CellValue
);
collects
.
Remove
(
data
);
}
cellIndex
++;
}
}
}
}
}
public
void
WriteSheetData
(
ISheet
sheet
,
PerSheetPoint
point
,
SheetType
sheetType
,
ExcelStyle
style
,
object
data
,
Dictionary
<
ExDataDict
,
object
>
exdict
=
null
)
public
void
WriteSheetData
(
ISheet
sheet
,
PerSheetPoint
point
,
SheetType
sheetType
,
ExcelStyle
style
,
object
data
,
Dictionary
<
ExDataDict
,
object
>
exdict
=
null
)
{
{
}
}
}
}
}
}
performance/Performance.Services/ExtractExcelService/WriteDataFactory.cs
View file @
237dfe08
...
@@ -36,9 +36,9 @@ public ISheetDataWrite GetWriteData(SheetType sheetType, ILogger logger)
...
@@ -36,9 +36,9 @@ public ISheetDataWrite GetWriteData(SheetType sheetType, ILogger logger)
factory
=
new
WorkloadDataWrite
(
logger
);
factory
=
new
WorkloadDataWrite
(
logger
);
break
;
break
;
//
case SheetType.AccountBasic:
case
SheetType
.
AccountBasic
:
//
factory = new AccountBasicDataWrite();
factory
=
new
AccountBasicDataWrite
();
//
break;
break
;
case
SheetType
.
SpecialUnit
:
case
SheetType
.
SpecialUnit
:
factory
=
new
SpecialUnitDataWrite
(
logger
);
factory
=
new
SpecialUnitDataWrite
(
logger
);
...
...
performance/Performance.Services/PerExcelService/SheetDataRead/PerSheetDataReadDeptAccounting.cs
View file @
237dfe08
...
@@ -19,6 +19,7 @@ public class PerSheetDataReadDeptAccounting : IPerSheetDataRead
...
@@ -19,6 +19,7 @@ public class PerSheetDataReadDeptAccounting : IPerSheetDataRead
HeaderLastRowNum
=
1
,
HeaderLastRowNum
=
1
,
HeaderFirstCellNum
=
0
,
HeaderFirstCellNum
=
0
,
DataFirstRowNum
=
2
,
DataFirstRowNum
=
2
,
DataFirstCellNum
=
2
,
};
};
public
List
<
IPerData
>
ReadData
(
ISheet
sheet
,
List
<
PerHeader
>
perHeader
)
public
List
<
IPerData
>
ReadData
(
ISheet
sheet
,
List
<
PerHeader
>
perHeader
)
...
...
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