Puncte:1

Cum folosesc Feeds Tamper pentru a procesa mai multe coloane CSV într-un singur câmp?

drapel cn

Am un fișier CSV pe care îl import pe site-ul meu folosind Hrănește Tamper.

Fișierul CSV are coloane precum

  • calea URL
  • Leguma preferată
  • Fructul preferat
  • Pastele preferate

În Drupal, tipul meu de conținut are a Câmp JSONși vreau să import „Legumă preferată”, „Fructe preferate” și „Paste preferate” în câmpul JSON.

Există o modalitate de a mapa toate cele trei coloane favorite din fișierul CSV la câmpul JSON Drupal și de a combina valorile lor într-un plugin Tamper? Nu găsesc nicio modalitate de a extrage date din mai multe surse (cele trei coloane CSV) într-un plugin Tamper.

Iată structura unui plugin Tamper.

<?php

spațiu de nume Drupal\tamper\Plugin\Tamper;

utilizați Drupal\tamper\Adnotation\Tamper;
utilizați Drupal\tamper\TamperableItemInterface;
utilizați Drupal\tamper\TamperBase;

/**
 * Implementare plugin pentru importul CSV. Copiat din pluginul de codificare.
 *
 * @Tamper(
 * id = "json_import",
 * label = @Translation ("Import JSON"),
 * description = @Translation(„Import personalizat pentru JSON.”),
 * categorie = „Text”,
 * handle_multiples = TRUE
 * )
 */
clasa JsonImport extinde TamperBase {

  /**
   * {@inheritdoc}
   */
  funcția publică defaultConfiguration() {
    $config = parent::defaultConfiguration();
    returnează $config;
  }

  /**
   * {@inheritdoc}
   */
  funcția publică tamper($date, TamperableItemInterface $articol = NULL) {
    returnează $date;
  }

}
Puncte:3
drapel cn

Ok, iată modul corect de a face asta.

getSource() va returna o matrice cu chei pentru toate coloanele CSV.

Numele coloanelor sunt procesate după cum urmează:

  • cuvinte unice: Se păstrează scrierea cu majuscule. (galben, ciudat

  • cuvinte multiple: spațiile sunt înlocuite cu _ și toate litere mici. (Meta etichetă devine meta_tag)

    /**
     * {@inheritdoc}
     */
    funcția publică tamper($date, TamperableItemInterface $articol = NULL) {
      $csv_columns = $item->getSource();
    
      $json = [];
      $json['favoriteFruit'] = $csv_columns['favorite_fruit'];
      $json['favoriteVegetable'] = $csv_columns['favorite_vegetable'];
      $json['favoritePasta'] = $csv_columns['favorite_pasta'];
      $encoded_json = json_encode($json);
      returnează $encoded_json;
    }
    
Puncte:-1
drapel cn

Nu mi-am dat seama cum să accesez mai multe coloane CSV, dar o soluție este să folosești Excel sau alt software pentru foi de calcul pentru a crea o nouă coloană și a genera valorile JSON în Excel. Aceasta nu este o abordare bună, deoarece trebuie să faceți toate evadarile în Excel, ceea ce nu este distractiv și predispus la erori.

De exemplu, în Excel, puteți utiliza o formulă ca aceasta:

=CONCAT("{"+CHAR(34)+"fructe preferate"+CHAR(34)+":"+CHAR(34)+J3+CHAR(34)+","+CHAR(34)+"Legumă preferată"+ CHAR(34)+":"++CHAR(34)+K3+CHAR(34)+","+CHAR(34)+"favoritePasta"+CHAR(34)+":"+CHAR(34)+C3 +CHAR(34)+"}")

Apoi, în Feeds Tamper, trebuie să adăugați Codifica plugin și „Decode JSON” urmat de Codifica plugin din nou cu „Encode JSON”. Dacă JSON-ul dvs. nu are greșeli, acesta va fi importat în Drupal.

Postează un răspuns

Majoritatea oamenilor nu înțeleg că a pune multe întrebări deblochează învățarea și îmbunătățește legătura interpersonală. În studiile lui Alison, de exemplu, deși oamenii își puteau aminti cu exactitate câte întrebări au fost puse în conversațiile lor, ei nu au intuit legătura dintre întrebări și apreciere. În patru studii, în care participanții au fost implicați în conversații ei înșiși sau au citit transcrieri ale conversațiilor altora, oamenii au avut tendința să nu realizeze că întrebarea ar influența – sau ar fi influențat – nivelul de prietenie dintre conversatori.