Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 25b1500a

Von Tamino Steinert vor 10 Monaten hinzugefügt

  • ID 25b1500a73abe59ec538c0170641c0e00793e800
  • Vorgänger 20af1c62
  • Nachfolger 7413a26e

kuw: CSV-Import-Script um Farbtabellen erweitert

Unterschiede anzeigen:

scripts/import_variant_csv.pl
13 13

  
14 14
use Data::Dumper;
15 15
use List::Util qw(first);
16
use File::Basename;
16 17

  
17 18
use SL::DBUtils;
18 19
use SL::LXDebug;
......
38 39

  
39 40
chdir($FindBin::Bin . '/..');
40 41

  
41
my ($opt_user, $opt_client, $opt_part_csv_file, $opt_groessen_staffeln_csv_file);
42
my (
43
  $opt_user, $opt_client,
44
  $opt_warengruppen_csv_file, $opt_farben_folder,
45
  $opt_part_csv_file, $opt_groessen_staffeln_csv_file
46
);
42 47
our (%myconfig, $form, $user, $employee, $auth, $locale);
43 48

  
44 49
$opt_client = "variant";
45 50
$opt_user   = "test_user";
46 51

  
47
$opt_part_csv_file = "Artikel_komplett.csv";
48

  
49
$opt_groessen_staffeln_csv_file = "Größenstaffeln.csv";
52
$opt_warengruppen_csv_file = "kuw/Warengruppen.csv";
53
$opt_groessen_staffeln_csv_file = "kuw/Größenstaffeln.csv";
54
$opt_farben_folder = "kuw/Farben";
55
$opt_part_csv_file = "kuw/Export_bearbeitet.csv";
50 56

  
51 57

  
52 58
$locale = Locale->new;
......
86 92
my %parts_mapping = (
87 93
  VK                      => 'sellprice',
88 94
  EANNR                   => 'ean',
89
  WAR_KURZBEZEICHNUNG     => 'description',
90
  WARENGRUPPENBEZEICHNUNG => 'warengruppe',
95
  EIGENEARTIKELNR         => 'description',
96
  WAR_KURZBEZEICHNUNG     => 'warengruppe',
91 97
  GROESSE                 => 'varianten_groesse',
92 98
  LAENGE                  => 'varianten_laenge',
93 99
  FARBNR                  => 'varianten_farbnummer',
......
171 177
$groessen_staffel_csv->parse or die "Could not parse csv";
172 178
my $groessen_staffel_hrefs = $groessen_staffel_csv->get_data;
173 179

  
180
my $warengruppen_csv = SL::Helper::Csv->new(
181
  file        => $opt_warengruppen_csv_file,
182
  encoding    => 'utf-8', # undef means utf8
183
  sep_char    => ';',     # default ';'
184
  quote_char  => '"',     # default '"'
185
  escape_char => '"',     # default '"'
186
);
187
$warengruppen_csv->parse or die "Could not parse csv";
188
my $warengruppen_hrefs = $warengruppen_csv->get_data;
189

  
174 190
my $transfer_type = SL::DB::Manager::TransferType->find_by(
175 191
  direction => 'in',
176 192
  description => 'stock',
......
178 194

  
179 195
SL::DB->client->with_transaction(sub {
180 196

  
197
  # create farben listen
198
  foreach my $farb_csv_file (glob( $opt_farben_folder . '/*' )) {
199
    my $farb_csv = SL::Helper::Csv->new(
200
      file        => $farb_csv_file,
201
      encoding    => 'utf-8', # undef means utf8
202
      sep_char    => ';',     # default ';'
203
      quote_char  => '"',     # default '"'
204
      escape_char => '"',     # default '"'
205
    );
206
    $farb_csv->parse or die "Could not parse csv";
207
    my $farb_hrefs = $farb_csv->get_data;
208

  
209
    my $vendor_name = basename($farb_csv_file);
210
    $vendor_name =~ s/\.csv//;
211

  
212
    my $variant_property = SL::DB::VariantProperty->new(
213
      name         => "Farbliste $vendor_name",
214
      unique_name  => "Farbliste $vendor_name",
215
      abbreviation => "fa",
216
    )->save;
217

  
218
    my $pos = 1;
219
    SL::DB::VariantPropertyValue->new(
220
      variant_property => $variant_property,
221
      value            => $_,
222
      abbreviation     => $_,
223
      sortkey => $pos++,
224
    )->save for
225
      map {$_->{Joined}}
226
      @$farb_hrefs;
227
  }
228

  
229
  # create partsgroups
230
  my @hierachy_descrioptions = qw(
231
    Bereich Hauptabteilung Abteilung Hauptwarengruppe Warengruppe
232
  );
233
  my %current_partsgroup_hierachy;
234
  foreach my $partsgroup_row (@$warengruppen_hrefs) {
235
    # TODO: store valid groessen staffeln
236
    my $valid_groessen_staffen = delete $partsgroup_row->{Größenstaffeln};
237
    my $last_hierachy_key;
238
    foreach my $hierachy_key (@hierachy_descrioptions) {
239
      if ($partsgroup_row->{$hierachy_key}) {
240
        my ($number, @rest) = split(' ', $partsgroup_row->{$hierachy_key});
241
        my $name = join(' ', @rest);
242
        unless ($number && $name) {
243
          die "Could not find number and name for $hierachy_key partsgroup '".$partsgroup_row->{$hierachy_key}."' in the row:'\n".
244
          join(';', map {$partsgroup_row->{$_}} @hierachy_descrioptions);
245
        }
246
        my $partsgroup = SL::DB::PartsGroup->new(
247
          partsgroup  => $name,
248
          sortkey     => $number,
249
          description => "$number $name",
250
          parent_id   => $last_hierachy_key ? $current_partsgroup_hierachy{$last_hierachy_key}->id : undef,
251
        )->save;
252
        $current_partsgroup_hierachy{$hierachy_key} = $partsgroup;
253
      }
254
      my $last_hierachy_key = $hierachy_key;
255
    }
256
  }
257

  
181 258
  # create groessen staffeln
182 259
  foreach my $groessen_staffel_row (@$groessen_staffel_hrefs) {
183 260
    my $name = delete $groessen_staffel_row->{BEZEICHNUNG};
......
200 277
      keys %$groessen_staffel_row;
201 278
  }
202 279

  
203
  die "end";
204

  
205
  my %partsgroup_name_to_partsgroup = map {$_->partsgroup => $_} @{SL::DB::Manager::PartsGroup->get_all()};
206
  my %vendor_name_to_vendor = map {$_->name => $_} @{SL::DB::Manager::Vendor->get_all()};
207
  my %warehouse_description_to_warehouse = map {$_->description => $_} @{SL::DB::Manager::Warehouse->get_all()};
280
  my %partsgroup_name_to_partsgroup = map {lc($_->partsgroup) => $_} @{SL::DB::Manager::PartsGroup->get_all()};
281
  my %vendor_name_to_vendor = map {lc($_->name) => $_} @{SL::DB::Manager::Vendor->get_all()};
282
  my %warehouse_description_to_warehouse = map {lc($_->description) => $_} @{SL::DB::Manager::Warehouse->get_all()};
208 283

  
209 284
  my @all_variant_properties = @{SL::DB::Manager::VariantProperty->get_all()};
210 285
  # create parts
......
220 295
      my $vendor_name = $first_part->{vendor_name};
221 296
      my $makemodel_model = $first_part->{makemodel_model};
222 297
      my $best_sellprice = first {$_} sort map {$_->{sellprice}} @$grouped_variant_values;
223
      my $partsgroup = $partsgroup_name_to_partsgroup{$partsgroup_name} or die
298
      $best_sellprice =~ s/,/./;
299
      my $partsgroup = $partsgroup_name_to_partsgroup{lc($partsgroup_name)} or die
224 300
        die "Could not find partsgroup '$partsgroup_name' for part '$makemodel_model $description'";
225
      my $vendor = $vendor_name_to_vendor{$vendor_name} or
301
      my $vendor = $vendor_name_to_vendor{lc($vendor_name)} or
226 302
        die "Could not find vendor: '$vendor_name' for part '$makemodel_model $description'";
227
      my $warehouse = $warehouse_description_to_warehouse{$warehouse_description} or
303
      my $warehouse = $warehouse_description_to_warehouse{lc($warehouse_description)} or
228 304
        die "Could not find warehouse '$warehouse_description' for part '$makemodel_model $description'";
229 305
      my $parent_variant = SL::DB::Part->new_parent_variant(
230 306
        description => $description,
......
273 349
          @all_variant_properties;
274 350

  
275 351
        if (scalar @{$best_match->{missing}}) {
276
          die "Could not find variant property with values '@{$needed_property_values}'.\n" .
352
          die "Could not find variant property with values for $property_name '@{$needed_property_values}' of part '$makemodel_model $description'.\n" .
277 353
          "Best match is ${\$best_match->{property}->name} with missing values '@{$best_match->{missing}}'";
278 354
        }
279 355
        $property_name_to_variant_property{$property_name} = $best_match->{property};
......
293 369

  
294 370
        my $variant = $parent_variant->create_new_variant(\@property_values);
295 371

  
372
        my $sellprice = $variant_values->{sellprice};
373
        $sellprice =~ s/,/./;
296 374
        $variant->update_attributes(
297 375
          ean => $variant_values->{ean},
298 376
          description => $variant_values->{description},
299
          sellprice => $variant_values->{sellprice},
377
          sellprice => $sellprice,
300 378
        );
301 379

  
302 380
        # set stock

Auch abrufbar als: Unified diff