メインコンテンツに移動

メインナビゲーション

  • ホーム
  • サイトマップ
  • ビデオ
  • ご連絡

パンくず

  • ホーム
  • Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定

Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定

drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
drupal
feeds
customization

Feedsの機能

  • いろいろなフォーマットのデータをDrupalのデータ構造(例:ユーザー/ノード/Taxonomyなど)に合わせてインポートする
    • 一対一のコンテンツデータ(例:User -> Userデータ)
    • いろいろなフォーマットデータ(例:RSS/OPML/Atom feeds、csvなど)を各種Drupalのコンテンツ(例:User,Articleなど)データのインポート
    • PubSubHubbub のサポート
  • Feeds APIが提供されているので、独自のFetcher,Parser,Processorのプラグインの追加が可能
  • 基本設定:インポーターの名前、実行タイミングなどの設定
  • Fetcher: インポートするデータ/ファイルのフォーマット、場所などの指定
  • Parser: インポートデータの解析方法の指定
  • Processor: 出力するデータのフォーマット/コンテンツ、インポートデータのフィールドマッピングの指定

 

drupal
drupal
feeds
customization

インストールされたモジュール

  • Feeds : 7.x-2.0
  • Feeds Tamper : 7.x-1.0

Feeds Tamperが文字コード変更機能はない

  • Excelで作成したcsvファイルがShift-JISコードになる
  • DBのエンコードがUTF-8を指定してるため、Feedsでcsvデータをインポート時にDBエラーが発生する
  • csvファイルインポート時に使用するFeeds Tamperに文字コード変換機能がない
  • いろいろ調べて、Feed TamperにUTF-8に変換プラグイン(Feeds Tamper UTF-8 Encode)があることが分かった、さっそくチェックアウトして、サーバーにインストールした
  • Feeds Tamperのプラグイン設定画面でUTF-8変換項目がメニューに現れた
  • 実際にデータをインポートしてみたら、データインポートができたが、インポートされた文字が化けっている

Feeds Tamper UTF-8 Encodeプラグインを修正

  • Feeds Tamper UTF-8 Encodeが比較的にシンプルで修正しやすい
  • sites/all/feeds_temper_utf_8_encode/plugins/utf8_encode.incにコード変換ロジックがうまく作動していないようで: 
     /**
     * Encode the field and return the encoded value.
     */
    function feeds_tamper_utf8_encode_callback($result, $item_key, $element_key, &$field, $settings, $source) {
    //  $field = utf8_encode($field);
    	$field = iconv(null, 'utf-8', $field);
    }
     
  • 上記コードを以下のように修正
    /**
     * Encode the field and return the encoded value.
     */
    function feeds_tamper_utf8_encode_callback($result, $item_key, $element_key, &$field, $settings, $source) {
    //  $field = utf8_encode($field);
        $field = iconv(null, 'utf-8', $field);
    }
  • 修正したプラグインはここからダウンロードができる

 

添付 サイズ
feeds_tamper_utf_8_encode.zip (11.18 KB) 11.18 KB
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
drupal
data import
feeds
customization

インストールされたモジュール

  • Feeds : 7.x-2.0

不明な値:GUID

  • CSV Parserでcsvファイルをインポートする
  • Processorでデータマッピング時にGUIDをどのように設定すればいいかは不明
  • インポートするcsvファイルにどのようなキーをGUIDにセットするかは不明

GUIDがcsvファイルインポート時にユニークチェックを利用している

  • GUIDがどこに保存しているか、どのような性質なフィールドか?
    • GUIDがテーブル:feeds_item(Feedsがインストール時に作成されたテーブル、インポートデータ履歴、インポートされたデータ削除に利用される)にある
    • GUIDの性質:Text型、Unique idenfiierと指定されている ⇒ 重複しない文字列、数字でよい、桁数(65,535バイト)があまり心配がない
  • csvインポートファイルに任意のキーをGUIDにセットして、データの重複チェックが可能
    • GUIDにセットしたcsvデータのキーが重複した場合、インポート時にSQL文エラーが発生される
  • Feedsのデータインポート設定画面(Home » Administration » Structure » Feeds importers)で重複チェックの設定する
    • Mapping画面でcsvデータのキーをGUIDにセット、GUIDを「Used as unique.」として設定する
    • Setting画面で既存データ(インポートしたデータ)に重複した場合に更新するか否かをチェックして設定する
  • 問題点:インポートデータに重複がある場合、どのようにエラーを出すかは不明

 


 

drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

問題点:Drupalのモジュール(Feeds)でデータインポート(データ更新も含む)時にアクセス権限がないエラー

  • 環境: Drupal7.54、Feeds7.x-3.0
  • やりたいこと:Feedsでノードタイプへのデータのインポートと更新を行います
  • データ更新時にアクセス権限エラーが発生
    The user bear is not authorized to update content of type chinese_word. To import this item, either the user "bear" (author of the item) must be given the permission to update content of type chinese_word, or the option "Authorize" on the Node processor settings must be turned off.
    Drupalのモジュール(Feeds)でのデータ更新時にアクセス権限エラー

モジュールFeedsのノードプロセッサー設定画面ある「投稿者」設定が新規作成時のみに使用され

  • ノードプロセッサー(Node Processor)の設定画面にある「投稿者」があります。ただし、これはノードが作成時のみ使用され、データ更新の権限と関係ないです
    モジュールFeedsのノードプロセッサー設定画面にある「投稿者」がノード作成時のみに使用され
  • データ更新時にの「投稿者」と関係ないです

モジュール(Feeds)でデータ更新時に、コンテンツタイプデータの作成者のアクセス権限がチェックされます

  • Feedsでデータインポート時に権限設定が2種類あります
    • データインポート操作が可能かどうかの設定(今回のエラーと関係ない)
    • データ更新時にデータの作成者のアクセス権限
      Feedsでデータ更新時にデータの作成者がデータ更新権限チェック
  • コンテントタイプのデータ作成者が必ず更新する権限とは限りませんので、ここで、チェックを行います
  • 但し、データインポートなので、通常データの作成者と関係ないので、チェックしなくてもよいかと思います

サイト移行時にデータへのアクセス権限などがうまく行っていないようです

  • 元々作成者が自分のデータを更新する権限を与えたが、何かの原因(おそらくサイト移行時の作業)で、更新権限が外されました。
  • データインポート時にエラーが発生されました。
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
development
feeds

モジュール(Job Scheduler)がバックグランドでタスクを実行する便利なツールの一つ

  • 環境:Drupal7.54、Job Scheduler7.x-2.0
  • モジュール:Feedsに依存され、バッググランドタスク実行に利用されている
  • Job Schedulerの単独利用も可能だが、管理UIが無くて、ほとんどAPIとしてバックグランドジョブとしての利用
  • Job Scheduler APIの利用は以下のステップとなります
    • hook_cron_job_scheduler_info()の実装(タスクを実行するコールバック関数名の定義)
      /**
       * Implements hook_cron_job_scheduler_info().
       */
      function drills_custom_feeds_cron_job_scheduler_info()
      {
        $schedulers = array();
        $schedulers['chinese_sentence_import_scheduler'] = array(
            'worker callback' => 'chinese_sentence_import',     // タスク内容のコールバック
        );
        return $schedulers;
      }
      
    • 定義されたタスクのコールバック関数を定義
      function chinese_sentence_import($job) {
      
            //  実際のタスク処理ロジック
      
      }
    • 上記処理内容をスケジュールに設定
        //Add a job.
        $job = array(
            'type' => 'story',     // 任意の識別名
            'id' => 20170309,      // 任意のID(例:日付)
            'period' => 3600,      // 実行開始時間(例:3600秒後から実行)
            'periodic' => FALSE,   // 周期的に実行か(FALSE:一回のみ、TRUE:周期的)
        );
        JobScheduler::get('chinese_sentence_import_scheduler')->set($job);
      
    • 上記コードが実行されると、job_scheduleに一レコードが生成され、cronが実行時に、セットされた実行開始時間を比較して、バックグランドで実行されます
      モジュールJob Scheduleが簡単に実装される

Job Schedulerモジュールは長い処理時間(30秒以上)のジョブに適していない

  • モジュールの構造としてはシンプルで、使いやすいです。
    • 一つのジョブに一つのタスクコールバックしかありません(すべてのタスク処理がのコールバックに記述する必要があります)
  • 一度に200ジョブまで、30秒までの処理が制限されていています
    • job_scheduler.moduleでjob_scheduler_cronの処理部分を確認すれば、30秒までの処理が記述されています
      JobSchedulerモジュールのタスク処理制限:30秒以内、200個ジョブまで
    • 30秒以上になると、次のジョブが処理しなくなります

Job Schedulerモジュールで長時間かつ一度実行のみのタスクを実行させる裏技

  • 時に数時間のタスクを実行する必要の場合がありますが、一度のみの実行であれば、以下の方法を試して良いでしょう
  • JobSchedulerクラスがジョブ(Job)をセットすることではなく、dispatch関数(cron実行されたときに、この関数で各ジョブを実行させる)を利用して、即時にタスクを実行させます
     JobScheduler::get('chinese_sentence_import_scheduler')->dispath($job);
  • 上記タスクを実行させるブラウザが返答を待ち状態になりますが、無視してブラウザを閉じっても構わないです。
    • バックグランドで実行しているので、成功するか、失敗する分かりません。
    • タスク実行時に結果をどこかに出力(例:watchdogでレポートに出力)して、確認する方法があります
  • Feedsがデータインポート時にこの方法の利用はできません。
    • Feedsがバックグランドジョブの設定は即時実行タイプ(dispath)ではないからです。
    • 無理矢理にFeedsのコード修正して、実行させることができますが、ほかのインポート対象に影響を与えないため、コードの回復が必要でしょう
drupal
development
data import

Drupalのバッチ(Batch)が複数のオペレーション(Operation)から構成され

  • 一つのバッチに一つ以上のオペレーションから構成される
    一つのバッチに一つ以上のオペレーションがある
  • オペレーション単位でバッチプログレスの状態を管理しています(プログレス・バーと言う)
  • 基本的なバッチプログラムは以下のようで
    // バッチ定義の配列
    $batch=array{
        'title' => t('バッチのタイトル'),   // バッチの名前
        'operations' => array(),      // オペレーション配列
        'finished' => 'import_finished_callback', //終了時のコールバック関数
        'progress_message' => t('Finished @current out of @total.'), // 状態表示
    }
    // オペレーション配列の定義
    $batch['operations'][] = array('batch_operation_function_1', array( [引数が無ければ、空の配列] ) );
    $batch['operations'][] = array('batch_operation_function_2', array( $arg_1, $arg_2 ) );
    ・・・・・・
    // バッチの実行
    batch_set($batch);
    
    // オペレーション関数
    function batch_operation_function($arg_1, $arg_2, &$context){
    
      // バッチ内の処理
    
    }

一つのオペレーション内に大量なループ、長時間の作業ロジックを避けるべき

  • バッチの各作業しているオペレーション内でで長い時間のタスクや、大量ループなどより、オペレーションが異常終了のことがあります(メモリや、タイムアウトなどの可能性)
  • 各作業を細分化して、オペレーション単位で実行させます
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

モジュール(Feeds)が非階層化されているタクソノミータームのインポートが可能

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのcsvファイルインポートについて、「Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考にしてください。
  • 非階層化のタクソノミータームcsvデータは以下のよう
    DrupalのFeedsで非階層化のタクソノミータームのインポート
  • タクソノミータームのインポート操作はビデオを参考にしてください
  • プロセッサーのマッピング設定ポイント:
    • 記事のタイトルをキーにして、タイトルでインポートデータを記事との照合(タイトルは重複しない前提)
    • タクソノミータームが存在しない場合、新規作成を行います
    • タクソノミーターム名を照合してインポートします
  • csvデータをインポートしたら新規作成したタクソノミータームの確認

モジュール(Feeds tamper term hierarchy)で階層化されたcsvタクソノミータームデータのインポート

  • 必要なモジュール:Feeds tamper term hierarchy(サンドボックスプロジェクト、ダウンロードはここ)
  • 以下のような階層化されたcsvタクソノミータームデータをインポートします
    Drupalのモジュール(Feeds tamper term hierarchy)で階層化されたタクソノミータームのインポート
  • 具体的なインポート方法はビデオを確認してください。
  • 既存のタクソノミータームのデータマッピング時に以下の注意点:
    • 既存のタクソノミータームの新規作成チェックを外します(Feeds tamper term hierarchyが同じ機能があったため)
    • タクソノミーターム検索は「名前」ではなく、タームIDで検索するとの設定
  • TamperのFeeds tamper term hierarchyで設定は、「Term hierarchy separator」(csvデータのターム親子区切り)がインポートデータにある区切り記号と一致していることの確認
Embedded thumbnail for Drupalのモジュール(Feeds)で階層化されたタクソノミータームのインポート
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
system_management

モジュール(Localization Update)でサイトの多言語ユーザーインターフェースを導入します

  • 背景:Drupal7.54、Localization Update7.x-2.1
  • モジュール(Localization Update)をインストール/有効化します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)で「言語を追加」リンクをクリックすると、必要なユーザーインターフェース言語の導入ができます

管理者がサイト単位でユーザーインターフェース言語の一括設定(ほかの言語を使用しない)

  • Druaplを初期インストール(英語バージョンの場合)後に、別の言語(例:日本語)を導入し、その言語のみを使用します
  • 言語設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語)でのデフォルト値を選択すればよいです
    サイト単位の言語設定
  • サイト管理者が選択してから、一般ユーザーの選択はできません。

複数の言語をユーザーインターフェースとして利用する場合に、URL/ブラウザ/セッション/ユーザーの言語設定などよりサイトの言語自動判別ができます

  • 複数のユーザーインターフェース言語がある場合、どれを使用するかは決める必要があります
  • 言語判別設定画面(ホーム » 管理 » 環境設定 » 地域と言語 » 言語 » 判別と選択)言語利用の判別条件を設定します
    言語の判別設定と判別順序設定
    • URL: URLから言語を判定する(パス接頭語かドメイン)
    • セッション: 言語をrequest/sessionパラメーターから判定する。
    • ブラウザ: ブラウザーの言語設定から言語を判定する。
    • ユーザー: ユーザープロフィールで設定した言語に従う。
    • デフォルト: サイトのデフォルト言語を使う
  • 上記判別方法のい任意、または全部の選択はできます
  • 判別の優先順のソートができます
  • URLで言語判断設定した場合、URLのドメイン/パス接頭語の設定が必要となります
    言語判別のURLドメイン/パス接頭語設定
    • 「言語のドメイン」と「言語コードのパス接頭語」のどちらかの設定(両方の設定はできない)
    • 設定された方式で言語を判別となります
    • 説明の言葉通りに、一度設定したら、変更時にすでに存在しているパスが使用できなくなりますので、ご注意ください(変更後にすべてのパスを再構築などの作業が必要)
      言語判定URLの設定
Embedded thumbnail for Drupalの多言語ユーザーインターフェースの導入と設定
drupal
video
feeds

やりたいこと:Feedsで多言語コンテンツデータのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Feeds:Enity Translation7.x-1.0
  • モジュール:Entity Translationで多言語サイトを構築しています
  • 複数の言語コンテンツをデータ移行したいです
  • いろいろ調べてみてた、同一フィールドに多言語インポート方法が少なく、難しそうです

解決方法:モジュール(Feeds:Entity Translation)で多言語コンテンツデータの移行

  • 多言語コンテンツデータ移行をサポートするモジュールがあまり多くないようで、一つモジュール(Feeds: Entity Translation)を見つけました
  • モジュール(Feeds: Entity Translation)をインストール/有効化したら、Feedsのデータマッピング管理画面に、多言語有効なフィールドの各言語対応ターゲットが現れます
    多言語コンテンツデータ移行にサポートするFeeds: Entity Translation
  • 同一フィールドの各言語対応ターゲットを選択して多言語コンテンツインポートができました
Embedded thumbnail for DrupalのFeedsで多言語コンテンツデータのインポート
drupal
feeds
module usage

注意点:Drupalのモジュール(Feeds)の設定が間違うと手動でデータインポートができなくなります

  • 環境:Drupal7.54、Feeds7.x-3.0
  • やりたいこと:手動でデータをインポート(例:csvファイルからのインポートなど)
  • Feedの基本設定のところある二か所をチェックしないと手動でのインポートができない
    • 添付するコンテンツタイプ:スタントアローンのフォームを使う
    • 投稿時にインポート
      Drupalのモジュール(Feeds)の設定が間違うと手動でのインポートができない
    • 初期としてはこの二つ設定を有効にしています
  • ちなみに、「投稿時にインポート」を無効の場合、バッチでデータインポートすることになります(バッチの設定が必要)
  • 添付するコンテンツタイプ:「スタントアローンのフォームを使う」以外の選択肢を選択すると、インポート画面(ホーム » インポート)に当該インポーターはありません

手動でインポートできないときに画面上に「インポートされた項目はありません」が表示されます

  • 「投稿時にインポート」オプションが無効の場合、手動でデータインポートはできません
  • インポートデータがあるにはかかわらず、画面上に「インポートされた項目はありません」として表示されます
  • バッチにインポートジョブを入れたメッセージはありません
drupal
customization
feeds

やりたいこと:モジュール(Feeds)でのデータマッピング時にPHPコードでフィールド値を加工する

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Tamper7.x-1.1、Feeds Tamper PHP7.x1.2
  • Feedsデータインポートの基本は「 Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本) 」を参考してください
  • データマッピングに、各インポートフィールドの値を加工するため、Feeds Tamperモジュールが良く利用します
  • この中に、特殊なフィールド値加工(例:既存のデータを取得するなど)のためFeeds Tamper PHPを利用して、PHPスクリプトの実行ができます
  • Feeds Tamper PHPでインポートデータの扱い、以下のパラメーターで、任意のフィールドの値の利用ができます
    • $field: 渡されたフィールドの値
    • $item['フィールド名']: インポート元で定義していたフィールド名でその値を取得する
      Drupalのモジュール(Feeds)のデータマッピング時にFeedsTamperでのPHPコードより各フィールドの値を加工します
  • 任意のフィールド(例:body)で他のフィールドの値(例:title)の取得することができます

注意点:PHPコード実行のセキュリティ問題とパフォーマンスへの影響

  • PHPコードを実行するには、eval()関数で行うため、任意のPHPコードの実行が可能となります
  • 特にインポートが公開の場合、PHPコード実行のセキュリティ問題を注意深く対応すべきです
  • また、データ取得したり、多くループをしたりして、パフォーマンスへの影響が考えるべきです
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
feeds
module usage

問題点:モジュール(Feeds)でデータインポート時に間違って設定があった場合インポートエラーなどが発生

  • 環境:Drupal7.54、Feeds7.x-2.0、Feeds Import Previews7.x-1.x
  • 複雑なデータマッピング設定(例:Feeds Tamperなどで)時に、間違いやすくなります。その場合実際のデータをインポートで確認する必要があります
  • 間違った設定より、データインポートエラーなどが発生します

解決:モジュール(Feeds Import Preview)でインポート設定を確認します

  • モジュール(Feeds Import Preview)でデータインポート直前のステップまでに進んで、実際のインポート設定の確認ができます
    Drupalのモジュール(Feeds Import Preview)でデータインポート設定の確認ができます
  • 実際にソースから各フィールドの値が表示されています。
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)
drupal
video
feeds
module usage

やりたいこと:コンテンツ(例:記事)のbodyフィールドの多言語データのインポート

  • 背景:Drupal7.55、Feeds7.x-2.0、Entity Translation7.x-1.0
  • コンテンツのbody以外のフィールドがEntity Translation有効であれば、Feedsのデータマッピングで複数の言語のターゲットが現れます
    • drupalのfeedsで多言語コンテンツデータのインポート
  • BodyにEntity Translation有効の場合にマッピングでのターゲットが一つしかありません
  • 複数回でそれぞれの言語データをインポートします
    DrupalのFeedsで多言語bodyデータのインポート

FeedsのNode Processor設定画面でコンテンツ(例:記事)の初期言語を設定

  • コンテンツの元言語を設定する必要があります(もし、設定しなければ多言語の表示に影響しないが、コンテンツの翻訳タグが表示されない)
  • Node Processor設定画面でノートの言語を選択して、データインポート時に設定してくれます(ビデオを参考)

Feedsのマッピング設定画面でbodyのインポート言語設定を行います

  • データマッピング管理画面でbodyフィールドに言語設定があります
    データマッピング管理画面でbodyフィールドの言語設定
  • 複数の言語に対して複数のインポーターを用意するか、複数回で言語設定を行います

各言語に応じて複数回を分けてデータインポートする必要があります

  • 言語ごとにデータインポートする必要があります
    • 一括して同一フィールドに複数の言語インポートができません
  • 具体的なステップはビデオを参考してください
Embedded thumbnail for Drupalのモジュール(Feeds)で多言語フィールドデータのインポート
drupal
drupal
customization
feeds
data import

目的

  • Entity Typeデータにほかのデータ(例:csv、xmlなど)からのインポートを可能にする
  • Feedsの初期データ変換プロセッサーに「Entity Type」のものがなかった

解決の選択肢

  • Feed Importモジュールでのデータインポート
  • Feedsモジュールのカスタマイズをする

ここでの解決:Feedsのカスタマイズ

  • インストールされたモジュール
    • Feeds :  7.x-2.0
    • ECK  :  7.x-2.0
    • Entity API :  7.x-1.5
  • 上記モジュールのインストールと有効化
  • ECKでインポートデータタイプとBundleを作成する
    • 例: データタイプ:「組織データ」、Bundle:「xxxの組織データ」
    • 「組織データ」のプロパティ:title、uid、created、changedを使用する
    • 「xxxの組織データ」のフィールド:「組織コード」、「正式組織名」をテキストフィールドで追加

Feedsの紹介

  • Feedsが三つの部分から構成される:Fetcher、Parser、Processor
    • Fetcher:インポータデータの取得(例:File upload、external RSS Feedなど)
    • Parser:インポートデータの解析方法の指定(csv、xls、xml、RSSなど)
    • Processor:インポートデータの作成(Node、terms、usersなどのデータ作成)

 

FeedsにEntity Typeデータ変換プロセッサーに追加

  • PatchファイルをFeedsモジュールに当てる
  • Feedsのデータ変換プロセッサー設定画面にEntity Typeのデータ変換プロセッサー追加前後のイメージ
添付 サイズ
feeds_entity_processor-1033202-217.patch_.txt (16.03 KB) 16.03 KB
drupal
feeds
module usage

Feedsモジュールの基本使用:csvデータをノード(node)にインポート

  • 環境:Drupal7.54、Feeds7.x-2.0
  • Feedsのインポート機能を理解するには、csvデータインポートから始めたほうが良いでしょう
  • 例:コンテンツのタイトルと内容をインポートします
    DrupalのFeedsモジュールでcsvデータのインポート

注意事項:基本設定とプロセッサーの設定

  • 基本的なインポート操作はビデオを参考してください
  • 基本設定の内容に周期的なインポートが必要の場合にインポートの頻度を設定します
  • プロセッサーの設定
    • 新規ノートの作成許可するかの設定
    • 複数回のインポートが必要な場合に「 ハッシュチェックをスキップ 」をチェックします
    • 投稿者の設定はデータ新規作成のみに使用されます
    • コンテンツ更新の場合、コンテンツの作成者が更新権限がチェックされます
  • プロセッター設定について、記事「Drupalのモジュール(Feeds)で手動でデータインポート時の必須設定 」を参考してください
 
 
 
Embedded thumbnail for Drupalのモジュール(Feeds)でcsvデータをコンテンツにインポート(Feedsの基本)