Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
O
oacc_import_cdc
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Analyze
Value stream analytics
Contributor analytics
Repository analytics
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Le Filament
Opération Auto-Consommation Collective
oacc_import_cdc
Merge requests
!2
[UPD] allow import 15 minutes step file
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
[UPD] allow import 15 minutes step file
16.0-15-steps
into
16.0
Overview
0
Commits
3
Changes
1
Merged
Julien - Le Filament
requested to merge
16.0-15-steps
into
16.0
11 months ago
Overview
0
Commits
3
Changes
1
Expand
Merge request reports
Compare
16.0
version 1
a37e8405
11 months ago
16.0 (base)
and
latest version
latest version
de64c649
3 commits,
11 months ago
version 1
a37e8405
2 commits,
11 months ago
1 file
+
29
−
22
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
wizard/acc_operation_import_wizard.py
+
29
−
22
Options
@@ -115,30 +115,37 @@ class AccOperationImportWizard(models.TransientModel):
# Create Data for the CDC
message
+=
"
Lecture et import des données ... <br/>
"
for
row
in
file_reader
:
# Create 1st slot 0-30min
power_data
=
row
[
1
:]
# check case of csv line ending by delimiter
if
power_data
[
-
1
]
==
''
:
power_data
.
pop
()
slot_datetime_tz
=
datetime
.
strptime
(
row
[
0
],
"
%d/%m/%Y %H:%M
"
)
slot_datetime_utc
=
local_to_utc
(
slot_datetime_tz
,
"
Europe/Paris
"
)
self
.
env
[
"
acc.enedis.cdc
"
].
create
(
{
"
name
"
:
file
.
name
,
"
acc_operation_id
"
:
self
.
operation_id
.
id
,
"
acc_counter_id
"
:
counter_id
.
id
,
"
comp_data_type
"
:
computed_data_type
,
"
power
"
:
row
[
1
],
"
date_slot
"
:
slot_datetime_utc
,
}
)
# Create 2nd slot 30-60min
self
.
env
[
"
acc.enedis.cdc
"
].
create
(
{
"
name
"
:
file
.
name
,
"
acc_operation_id
"
:
self
.
operation_id
.
id
,
"
acc_counter_id
"
:
counter_id
.
id
,
"
comp_data_type
"
:
computed_data_type
,
"
power
"
:
row
[
2
],
"
date_slot
"
:
slot_datetime_utc
+
timedelta
(
minutes
=
30
),
}
)
# if 2 data it's a 30 min step file if 4 it's a 15 min one
if
len
(
power_data
)
==
4
:
timestep
=
15
else
:
timestep
=
30
for
index
,
power
in
enumerate
(
power_data
):
if
index
==
0
:
timestamp
=
slot_datetime_utc
else
:
timestamp
=
timestamp
+
timedelta
(
minutes
=
timestep
)
self
.
env
[
"
acc.enedis.cdc
"
].
create
(
{
"
name
"
:
file
.
name
,
"
acc_operation_id
"
:
self
.
operation_id
.
id
,
"
acc_counter_id
"
:
counter_id
.
id
,
"
comp_data_type
"
:
computed_data_type
,
"
power
"
:
power
,
"
date_slot
"
:
timestamp
,
"
timestep
"
:
timestep
,
}
)
# Update partner_id for retrieved cdc
domain
=
[
Loading