🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
RPA

RPA(Robotic Process Automation)は、ホワイトカラーの間接業務を人間に代行して自動的に行う技術や概念を指します。人間が繰り返すクリックやキーボード入力といった定型的なデスクワークを行うことから、仮想知的労働者(Digital Labor)と呼ばれることがあります。

UiPath

UiPathは、API連携による高い拡張性を持つ幅広いシステムに適用可能なRPAプラットフォームです。開発・設定ソフトウェアや管理コンソール、バックオフィスロボットなどのツールがあり、必要に応じて導入することが可能です。

Blue Prism

Blue Prismは、複数ロボットの統括管理RPAです。各企業の事業部門に分散されているロボットに対し、プロセスの制御・監視・実行・スケジュールを行うコンソールでロボットの運用を推進。内部統制を強化できます。

Q&A

解決済

2回答

12106閲覧

[BluePrism][UiPath]重複する列名があるExcelのテーブルをデータテーブルに取得するとき、どのようにしていますか?

sumire_cl

総合スコア228

RPA

RPA(Robotic Process Automation)は、ホワイトカラーの間接業務を人間に代行して自動的に行う技術や概念を指します。人間が繰り返すクリックやキーボード入力といった定型的なデスクワークを行うことから、仮想知的労働者(Digital Labor)と呼ばれることがあります。

UiPath

UiPathは、API連携による高い拡張性を持つ幅広いシステムに適用可能なRPAプラットフォームです。開発・設定ソフトウェアや管理コンソール、バックオフィスロボットなどのツールがあり、必要に応じて導入することが可能です。

Blue Prism

Blue Prismは、複数ロボットの統括管理RPAです。各企業の事業部門に分散されているロボットに対し、プロセスの制御・監視・実行・スケジュールを行うコンソールでロボットの運用を推進。内部統制を強化できます。

0グッド

0クリップ

投稿2019/11/13 05:21

編集2019/12/04 06:58

前提・実現したいこと

Excelの帳票を取り込んでデータテーブルにする、というような処理があります。

  • UiPathだと、Activities>Available>App Integration>Excel>Read Range
  • Blue Prismだと、MS Excel VBOの、Get Worksheet as Collectionのシリーズ
  • Automation Anywhereだと…… すみません、手元に環境がなくて…… Each Row in an Excel datasetとかでしたっけ……

このようなときに、ちゃんとしたテーブルに作ってくれてあれば、普通にデータテーブルに読み込めるんですが
同じ列名を何度も使用している帳票はけっこうあります。
たとえば「商品名」という列名が何度でも出てくるとか……。
そういうのだと、列名をデータテーブルのヘッダにして読み込むことができません。

このようなときに、どういう方法でデータテーブルに取り込めるところまで持っていくのがいわゆるベストプラクティスなのか?
というのをお伺いしたいです。

業務によっては2回目以降に出現した重複列名の列を削除してしまってもいいし(pythonのcolumns.duplicated()でFalseが返った列だけ選択するような)、あるいは2回目以降に出現した列名を「商品名2」「商品名3」と変更して生かしておく場合もあるかと思います。

私が考えた方法

  1. 1行目をヘッダにせず、データとしてデータテーブルに読み込みます(UiPathだとプロパティの「ヘッダの追加」チェックをOFF。Blue PrismだとMS Excel VBOのGet Worksheet as Collection Offsetを使い、Use Headerをfalseにする)
  2. どうにかして重複の列名を重複じゃないようにします
  3. 列名の重複がなくなったところで、1行目をヘッダにします(Blue PrismだとCollection ManipulationのSet Column Names From First Row。UiPathだと、できちゃってるDataTableの1行目をヘッダに変更するってどうやるんでしたっけ)

Blue Prismのほうは、重複列を削除してCollectionにするオブジェクトを書きました
イメージ説明

手順1のところでやめちゃって、列名は「Column1」「Column2」…… でいいじゃんという手もありますが
それだと列名がわかりづらく……。

[2019.12.04追記]
LINQでできるらしい、というお話をどこかでちらっと見ました。
UiPathの場合はAssignのアクティビティを使えばいけそうですが、
Blue Prismは、何のステージを使って、どう書いたらいけるのでしょうか?
とりあえずdllにsysytem.linqとSystem.Data.DataSetExtensionsを入れて、名前空間にsystem.linqを入れて
コードステージにLINQを書いてみたのですが、datatable対応してない的なエラーが出てしまいます。

補足情報(FW/ツールのバージョンなど)

私の環境では、UiPathはCEで、Blue Prismは6.3で、Excelは2016で使用しています。
できればコードステージで.NETで……とか、Excel側でマクロ書いて……という方法は極力避けたいです(コードを書いてしまうと、あとのメンテナンスがたいへんになる問題につながるので)。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

私の場合、そういったシチュエーションがそもそも発生しないように、業務手順の見直しをしてから実装しています。
そのパターンが発生するのは、大抵手作業のチェック用だったりというのが多いので・・・

どうしても発生してしまう場合はsumire_clさんの発言の通りリネームします。

投稿2019/12/19 11:22

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sumire_cl

2019/12/20 05:00

ですよね……手順の見直しマジ必要ですよね……心底そう思います。 まず入口のExcel(手作業で担当者が作ったものが送られてくる)の間違いがないか確認するところからやろうと思います。
guest

0

UiPathやとヘッダが重複していた場合は、「商品名_1」「商品名_2」のようにアンスコつけて取り込まれるかと、、、(UiPathのバージョン何でしょうか??CEというのは無料版という意で、バージョン情報がヘルプに出てくるかと)
しかし、私の場合ですと列名で取らず(row("商品名"))、row(0)と取ることがほとんどです。

投稿2019/12/11 04:33

KosukeWatanabe4

総合スコア36

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sumire_cl

2019/12/12 02:38 編集

CEは安定板じゃないほうにチェックを入れているので、バージョンは勝手にどんどん新しいやつになってると思います。 BluePrismは有償版なのでバージョンはこれで固定です。 UiPathは列名重複についてはUiPath側でよろしくやっておいてくれるのですね。LINQも使えるしUiPath便利ー……。
KosukeWatanabe4

2019/12/12 02:43

UiPathはVB.NETだけやなくてC#も書けるようになったのが凄いですよね汗 BluePrismの記述言語は何かわからないですが。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問