【Kintone】ファイルの一括登録(読み込み)を条件付きでした

https://jp.cybozu.help/k/ja/user/using_app/import_records/import_csv.html

 

上記のページを参考にファイルを読み込むことで一括で更新できることがわかりました。現在、xlsxファイルを読み込ませることで特定のフィールドの更新をかけようとしています。

一意のフィールドが例えばa,b,c,dという項目が入っていてエクセル側には

  • a,1
  • b,2
  • e,3

のような情報の持ち方をしていて、このエクセルファイルを読み込むことで、Kintone側のa,bそれぞれの値を持つレコードについて、他のフィールドにエクセル側の1や2といった紐づく値を取得することができました。

ここで問題は、Kintone側には情報がないeについてはなにも取得したくないのですが、あらたにeと3という値を持つレコードが生成されてしまいます。これをKintoneにあるa,bだけという条件で一括更新するような方法をさがしております。

 

どなたかアドバイスをお願いいたします。

 

エクセルからe,3の行を消してアプリにインポートする対応では不十分なのでしょうか。

コメントを頂き誠にありがとうございます。

説明不足で申し訳ございません。実際にはeがkintoneのアプリケーション側のレコードの存在するかはわからず、より厳密に申し上げれば数百件の行数がエクセルには存在しており、これをKintone側と照合してから読み込むのは非現実的な作業という状況でございます。

そのような事情があるため、エクセルのVlookUpのような感覚で該当があればそのレコードだけ更新したいという発想となります。

宜しくお願い申し上げます。

インポート先アプリのレコードをエクスポートしてExcelで突き合わせる方法が楽だと思いますが、手作業により誤る可能性がありますので、
標準機能だけでできる以下の方法はいかがでしょうか

  1. インポート先のアプリ(以下アプリA)をコピーしてアプリBを作成する
  2. アプリAから全レコードエクスポートしてアプリBにインポートする
  3. エクセルファイルをアプリBにインポートする
  4. アプリBから[更新日時 > 3のインポートが完了した日時] を条件にレコードをエクスポートする
  5. 4でエクスポートしたファイルをアプリAにインポートする

コメントありがとうございます。なるほど、一旦Bをかましてやるのですね。

因みに標準機能ではなくAPIを利用する方法も検討対象に入っているのですがPUTを使ってBody部分でid(a,b)が一致するものを条件としてループさせて更新をかけていくようなアプローチはあまり現実的ではないでしょうか?(総当たりになるので、処理は重くなることが予想されます)

 

ただ、その方法でも毎回JSONコードをJavascriptに貼って実行するのは自分じゃなきゃできないので、一般ユーザーにボタンを押せば対応できるようになるのかが不明ではありますが・・・

 

APIを利用するのであれば、ご提示されている方法でVBAで実装するとユーザーはボタンを押すだけで済みます。
その際、APIの実行回数が少なくなるように、エクセル上のキーをもとにkintoneからレコードを一括で抽出し突き合わせてから、
更新するのが良いと思います。

あ、Kintone側ではなく落としたデータのエクセル側のVBAで処理するということですね。ありがとうございます。