質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.35%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

2回答

1781閲覧

エクセルの顧客IDを統合したい

pennginn

総合スコア9

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

0グッド

0クリップ

投稿2020/07/13 07:17

前提・実現したいこと

◆実現したいこと
1、「顧客ID」が違うものかつ「名前」列が同一のデータの「顧客ID」を同じ物に更新したい。

◆前提条件
1、「名前」列には半角スペース等はないものとする。
2、該当ファイルはCSV。

◆該当のソースコード
該当箇所の検索までは以下関数でできたんですが、別セルに「重複2」と記載できるだけでどの行で条件が一致したかがわからず・・・
=IF(COUNTIF($G$2:G2600,G2600)>1,IF(COUNTIF($C$2:C2600,C2600)=1,"重複2","重複1"),"該当なし")

他言語で対応できるのはPHPかVBAなら多少できます。

◆言語
エクセル関数

試したこと

上記関数で該当箇所の発見まで・・・
PHPで対応も考え少し作ってみましたが、重複箇所の顧客IDの参照が思いつかず・・・
一応以下にPHPのコードも張っておきます。

<?php // ファイルの中身を配列で取得. $csv = file('sales_init_template_full_201904-07'); // ヘッダーを切り取る. $csv_header = $csv[0]; $csv_body = array_splice($csv, 1); int i=0; // 各行を配列に直す. foreach ($csv_body as $row) { $csv_body_dummy[i] = $row; $custemar_array = explode(',', $row); // 処理 //チェック列参照 if($custemar_array[15]=="重複2"){ //どうやって顧客IDを上書きすれば・・・ } i++; } ?>

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

特になし

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

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

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

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

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

takasima20

2020/07/13 08:07

ふり直す「顧客ID」はどういうのを使うのかな? (複数ヒットしたうちのひとつとか、新たに払い出すとか)
pennginn

2020/07/13 08:14

失礼しました。 顧客IDは半角数字の羅列です。 顧客IDは最終的に同じ名前ならすべて同一のIDにしたいです。 ふりなおすのは、名前が重複していたデータの顧客IDいずれかに統一しないといけません。 現状顧客IDはバラバラで名前が一緒の物があり、それを同じIDにしたいです。
guest

回答2

0

ベストアンサー

黄色のセルに入れています。あとは新顧客IDをコピーして顧客IDの列に値の貼り付けをすればよいです。
=IF(COUNTIF(R2C3:RC3,RC3)<>COUNTIFS(R2C2:RC2,RC2,R2C3:RC3,RC3),INDIRECT(ADDRESS(MATCH(RC3,RC3:R2C3,0)+1,2,1,0),0),RC2)
イメージ説明

投稿2020/07/13 08:48

thyda.eiqau

総合スコア2982

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

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

thyda.eiqau

2020/07/13 08:50

A1方式ならこうです =IF(COUNTIF($C$2:$C2,$C2)<>COUNTIFS($B$2:$B2,$B2,$C$2:$C2,$C2),INDIRECT(ADDRESS(MATCH($C2,$C2:$C$2,0)+1,2,1,0),0),$B2)
pennginn

2020/07/13 09:18

ありがとうございました!INDIRECTこんな使い方するんですね!勉強になりました!
thyda.eiqau

2020/07/13 09:19

vlookup相当のことをやりたいとき、vlookupは検索キーが一番左の列にある必要があるわけですが、一番左以外のところから動かせないときにindirect + address + matchが便利です。
guest

0

重複が有れば
下記のように行番号を取得すればいけるのでは?
https://www.relief.jp/docs/excel-vba-find-all-rows-number-columns-number.html

投稿2020/07/13 07:57

AMK

総合スコア765

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

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

pennginn

2020/07/13 08:17

VBAですね!ちょっとこれでやってみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問