• ベストアンサー

エクセル 一度に複数並び替えする方法?

 PCはwindowsXP ソフトはエクセル2003を使っています。  とある商品を倉庫で保管し、日々メーカーから送られてくる 出荷指示書に従い出荷する仕事をしています。  商品は四種類、納品先は30箇所ほどです。  メーカーから送られてくる出荷指示書は行き先一箇所につきA4用紙 一枚で送られてくるのですべての行き先に出荷がある場合40枚ほどに なります。  倉庫の出荷担当者が40枚めくって見るのは大変だから、出荷指示書を 一枚のリストにしてほしいというのでエクセルでリストを作っています が、その仮定でミスがたまにあり、そのミスが大きな損失につながって ます。  <例>◆メーカーからの出荷指示書(A4用紙横書き)     -1枚目-   納品日10/22   納品先 Aセンター   1L   6ケース   200ml  40ケース   ○○味 20ケース     -2枚目-   納品日10/22   納品先 Bセンター   ○○味 30ケース   1L   10ケース   200ml  20ケース    ↓ ↓ ↓この出荷指示書を以下のリストにエクセルで作り直す  行き先    1L 200ml ○○味1  ○○味2  Aセンター 6c/s 40c/s 20c/s  Bセンター 10c/s 20c/s 30c/s   ・     ・   ・    ・   ・     ・   ・    ・  問題は出荷担当者に渡すエクセルのリストの方は  商品の種類が「1L, 200ml, ○○味1, ○○味2」と 順番が決まってますが、例にあるとおり、メーカーから 送られてくる出荷指示書は常に順番がバラバラで エクセルのリストに作り直す仮定でたまにミスがあり、そのため 数をまちがえて出荷して賞味期限の関係でまちがえた分が再出荷 できない場合はまるまる会社が買い取りということになる場合が ありました。  入力したら必ず一度は見直ししているのですが、自分で入力したせ いで先入観があるのか見直ししてもまちがえていることがあるのです。  それで入力のしかたを変えようと思っています。  商品の順番は出荷指示書どおり入力して後から並び替えで 「1L, 200ml, ○○味1, ○○味2」となるようにしようと思っている のですが、問題は行き先40箇所分、範囲指定して並び替えを40回することになるということです。  行き先    1L    200ml    ○○味1    ○○味2  Aセンター  6c/s 40c/s 20c/s (ここまで範囲指定して並び替え)  行き先    ○○味1  1L     200ml     ○○味2  Bセンター   30c/s 10c/s 20c/s (ここまで範囲してして並び替え)    ・    ・    ・  これをすべての行き先に対して「1L, 200ml, ○○味1, ○○味2」の 順に一度で並び替えできるようなプログラムを組むことは できるでしょうか?  関数やマクロなどの知識もほとんど初心者ですが、がんばって 覚えようと思っています。  どなたか教えてください。よろしくお願いします。

質問者が選んだベストアンサー

  • ベストアンサー
  • hallo-2007
  • ベストアンサー率41% (888/2115)
回答No.5

No3です。以下はアドバイスです。 >40箇所分、40枚の紙でFAX来ます。 会社にスキャナーなどはありませんでしょうか。 今のスキャナー(或いはスキャナー付きプリンター等)では、印刷した文字をデータにしてくれる機能が付いているのがあります。 手書きでなく印刷されたFAXであれば、手入力の作業から楽できます。 > 商品は四種類、納品先は30箇所ほどです。 別途シートに 商品マスタ  商品ID 品名 単価 在庫  10001 1L  10002 200ml  10003  ○○味  10004  ○○味2 納品先マスタ  納品先ID 会社名 住所 電話番号・・・・ ・・・ の2つのシートは作成してください。 品名、会社名には、定義の名前をつけておきます。 入力する際の品名の列、会社名の列には入力規則でリストに設定します。 個数の列にも 入力規則で数値を設定します。 >それを「一枚の用紙に」リストを作るよう出荷担当者から頼まれました >担当者に渡すリストは >■縦の列・・・納品先(Aセンター、Bセンター、Cセンター) >■横の行・・・商品種類(1L, 200ml, ○○味1, ○○味2) 作業のダブルチェックを考えると、本日出荷の品名ごとの数量合計を渡す。 1L    120 200m   200 ○○味1 320 ○○味2 330 いった様な紙で、いったん倉庫から必要な数を取り出させます。 次に、納品書のシートに応じて、荷造りさせます。 取り出した商品が全て、なくなれば在庫ミスはなかったことになります。 手間の様に感じますが、一人の作業の中でダブルチェックが完了します。 >それとは別にぜひVBAを勉強しようと思っています。 良いことですが、その前に会社の仕事の流れを整理して頭に入れておく必要があります。 云われたことを単発に機能化したファイルを沢山作っても改善には結びつかないです。 ひとつのファイルで全体が管理できることを最終目標にします。

timothykun
質問者

お礼

返信ありがとうこざいます。 出荷時の作業のことまで気をつかって教えてくださり、本当にありがとうございます。  出荷作業ではまずは全行き先の商品ごとの総数を倉庫から出してから 行き先ごとに分けていく、というやり方がセオリーだと自分も思っていますが、自分は出荷担当の上司ではないので、そのやり方を「お願いはできても」「命令」はできない立場です。  今の出荷担当はそのやり方をしようとしません。  どこの会社も多いとは思いますが、作業員一人あたりある程度余裕があるような仕事量をあてているわけではなく、その出荷担当は他の商品の出荷も同時にやっているので、チェックよりも作業をひととりこなすので精一杯のようです。  とりあえず、出荷担当者に渡すリストには一番下に商品ごとの 総個数も出るように作ってあります。  そういう状況の中で自分はどうすることが他の担当の人との連携が うまくいかせることになるのか考えていますが、なかなか難しいです。  とりあえず、ピボットテーブルでの処理で作ったリストを使いながら、VBAを勉強していこうと思います。  指示書をFAXしてくるメーカーさんは、商品の種類の順番についても 数字の大きさについても全く改善してくれません。 本当に見えづらく、印刷状態も悪く「8と3と6」が区別がつきづらく いちいち電話で問い合わせる手間もかかりやりづらいです。  でもそのことに文句言ってても作業はすすまないので その与えられた情況の中でどうするかを考え、それをしていくしか ありません。とりあえず、この方向性でがんばってみます。  お付き合いくださり、本当に感謝します。  

全文を見る
すると、全ての回答が全文表示されます。

その他の回答 (4)

  • imogasi
  • ベストアンサー率27% (4737/17068)
回答No.4

読む気がしないほど質問分が長く、標題も何のことか良くわからない。 ●シートに入力直後のシートのデータの例を挙げよ。 ●最終出来上がりのシートの例または印刷の例を挙げよ。(->担当者別+商品別でよいのかな。商品の並び順はコード順?) ーー それで下記が改善のヒントになれば。 並び順は エクセルにはマクロの記録がある。ソートの操作も記録できる。 一度正しい操作をしてマクロの記録をとる。 それをボタンに登録する。このやり方はWEBで勉強のこと。 XX順。○○順などを2種類ぐらい作れば細かい間違いはなくなるのでは。(両者押し違えは別として)。多分1種類で済むはず。 ーー 出荷担当者ごとに別シートが要る(配る)のか。 ーーー そうなると合理化なんか考えるのだったら、VBAを勉強して、それで対処しないとどうしようも無いと思う ーーー 担当者数を繰り返すなら フィルタオプションの設定ででも担当者コードで抜き出しできる。 ーー 出荷指示書の入力は(もとのメーカーと電子化しないと)やむをえないとして、抜き出しーー>並べ替えーー>印刷を繰り返すのは、人間がするのがいやならVBAしかない。 あるいは担当者別に並べて、1担当者の分だけ紙に印刷し、全員分 自動印刷も出来る。後者の方が簡単。

timothykun
質問者

お礼

返信ありがとうございます。 文章力の問題、ごもっともです。よく知り合いに言われます。 これでも思い浮かんだままに文章を入力しているのではなく、 自分なりにどういう順番で話そうかなど考え、文章もなるべく短く なるように考えているので、文章を作る能力が足りないということだと 思います。 出荷担当者は一人です。 メーカーからの指示書は行き先ごとで別々の紙でFAXされてきます。 商品の順番もバラバラです。40箇所分、40枚の紙でFAX来ます。 <メーカーからのFAXの例-1枚目-> 納品日10/22   納品先 Aセンター ・200ml 40c/s ・○○味1 20c/s ・1L 6c/s (問題は商品名の順番が指示書によってバラバラなことです) それを「一枚の用紙に」リストを作るよう出荷担当者から頼まれました  担当者に渡すリストは  ■縦の列・・・納品先(Aセンター、Bセンター、Cセンター)  ■横の行・・・商品種類(1L, 200ml, ○○味1, ○○味2) 作成するリストの方は商品の種類の順番は固定です。 データの領域はそれぞれの出荷個数を入力します。  他の方の返信でも言いましたが、とりあえずはピボットテーブル での処理をしたリストを使い、それとは別にぜひVBAを勉強しようと 思っています。最終的には自分で作れるようになりたいです。

全文を見る
すると、全ての回答が全文表示されます。
  • hallo-2007
  • ベストアンサー率41% (888/2115)
回答No.3

>この出荷指示書を以下のリストにエクセルで作り直す >行き先    1L 200ml ○○味1  ○○味2 >Aセンター 6c/s 40c/s 20c/s >Bセンター 10c/s 20c/s 30c/s この様に入力されているのでしょうか。入力ミスしやすい、追加、変更に対応しにくいパターンだと思います。  納品日 行き先   品名 数量  10/22 Aセンター  1L   6  10/22 Aセンター  200mL  40  10/22 Bセンター  ○○味 30 ・・・・とメーカーの指示書みながら縦方向にデータを入れます。 変更や追加があれば、データを修正するではなく、  10/22 Aセンター  200mL -40 10/22 Aセンター  200mL  30 とか変更の記録が残るようにします。 後は、別シートにご希望の指示書、納品書のフォーマットを作成して 日付や行き先を入れると、一覧表が自動で作成されるような関数、VBAを準備すると言った手順です。 入力作業にも、VBAでフォームを作成したり、入力規則を設定したりして、ミスが発生しにくく、入力作業はしやすいファイルに仕上げていく。 といった手順に考えます。 入力シートは、入力しやすく、集計しやすく、記録が残る 印刷シートは、体裁のよいシートに出来上がります。

timothykun
質問者

お礼

返信ありがとうございます。 入力用シートと、印刷用シートは別にするというご意見 とても参考になりました。 やはり一人で考えているとこういう単純だけども効果的な 発想がなかなか浮かばないもので、より複雑な方にしていってしまう 傾向があるようです。  この際だから、VBAを勉強していこうと思います。  ありがとうございました。

全文を見る
すると、全ての回答が全文表示されます。
  • ASIMOV
  • ベストアンサー率41% (982/2351)
回答No.2

たぶん、ピボットテーブルでいけると思います メーカーからの出荷指示書を入力するときに次のように入れます A列:会社名(1行目に「会社名」と入れておく/以下同様) B列:商品名 C列:数量 これを、順番無視で入力します あとは、ピボットテーブルで 会社名を「行のフィールド」へ 商品名を「列のフィールド」へ 数量を「データーアイテム」にドラグします で、どうでしょう

timothykun
質問者

お礼

返信ありがとうございます。 なるほど。ピボットテーブルならばすぐにでもできますね。 でもいい機会なのでとりあえず、当分はピボットテーブルでの 処理をしたリストを使って、それとは別にVBAも覚えていって 自分でプログラムできるように勉強していこうと思っています。

全文を見る
すると、全ての回答が全文表示されます。
  • n-jun
  • ベストアンサー率33% (959/2873)
回答No.1

> 商品の順番は出荷指示書どおり入力して ここのシート構成を具体的に提示されては?

timothykun
質問者

お礼

返信ありがとうございます。 出荷担当に渡すリストは 本文の↓↓↓以下のものです。 一番簡単なのはメーカーから送られてくる出荷指示書の 商品の種類の順番を一定にしてもらうことなのですが、 メーカーさんにはそれを提案したらできないと言われたので こっちでなんとかするしかなくなってしまったのです。

全文を見る
すると、全ての回答が全文表示されます。

関連するQ&A

  • Excelでのランクの並び替えについて

    「S→A→B→C→D」の順番でデータを並び替えしたいのですが、 昇順で並び替えをすると「A→B→C→D→S」の順番になってしまいます。 これは手動で並び替えするしか方法はないのでしょうか? Excelについてあまり知識がありませんので、 簡単にできる事があればお教え下さい!

  • エクセルの並び替え

    エクセルの並び替えをしたいのですが、  最優先させるキー:A列  2番目:B列 のように並べ替えたいので B列を最優先させるキーに指定して並べ替え    ↓ OK   A列を最優先させるキーに指定して並べ替え をしました。ですが、こうなってしまいます   ↓↓ こうしたいのですが↓↓ A列      B列      A列   B列 1       A       1   A 1       B       1   A  1       C       1   B 1       A       1   B   1       B       1   C  1       C       1   C ちなみに本当は数字ではなく文字でユーザー設定リストを使って並べ替えています。分かりにくい質問で申し訳ないのですがお願いします。

  • エクセルの並び替えについて

    エクセルの並び替えについて質問させて頂きます。 下記のようにエクセルに文字列を入力しています。 A         B       1 10011   ホワイト 2        ブラック 3        ブルー 4 10002   ブラウン 5      レッド 6      イエロー 7 10005   パープル  8      ネイビー 9      サックス      A1に「10011」と入力してありますが、「10011」という品番に対してセルB1・B2・B3のホワイト・ブラック・ブルーのカラーが存在するという意味です。 ここで並べ替えを行いセルA1・A4・A7の数字を若い順(昇順)に並べ替えを行った場合、品番のみ昇順となり、カラーがその品番に対してキレイに並び替えが行われないのです。 最終的に下記のように並び替えを行いたいのですが、どのように並び替えを行えばよろしいでしょうか?よろしくお願い致します。 A    B    C   …    1 10002   ブラウン 2      レッド 3      イエロー 4 10005   パープル  5      ネイビー 6      サックス  7 10011 ホワイト 8      ブラック 9      ブルー     

  • エクセルの行列方向での並び替え

    エクセルのデータを下記のように並べ替えるのにはどうしたら宜しいのでしょうか?   1  2  3          1  2  3 A 1.23 2.85 1.11    A 2.85 1.23 1.11 B 12.34 15.72 15.57   B 15.72 15.57 12.34 C 16.07 16.99 15.93   C 16.99 16.07 15.93 ・   ・ ・       並び替え→      ・ ・   ・ E 16.94 14.87 13.87           E 16.94 14.87 13.87 上記のように行単位降順の並び替え方法を教えて下さい。 並び替えオプションで列単位として優先されるキー3行については並び替えができますが、データを一括に並び替えしたいのです。  

  • エクセル並び替え

    エクセルの並び替えで苦戦しております。 セルA.B内のデータとセルC.D内のセルを行で一致させたいんですが 出来ますでしょうか。 また、セルA内のデータにセルB内のデータをA内の文字の後ろにつけ加えることはできるでしょうか?

  • Excelの住所による並び替え

    Excel2010を使用しています。 A列 顧客名 B列 住所 C列 顧客履歴 のデータがあります。 C列の顧客データはA列の顧客に対して複数行あります。 このとき、住所のB列で地域ごとに並び替えをしたいと考えています。 住所は、○○県○○市○○町1-2-3のようになっています。 しかし住所登録によっては、 ○○県○○郡○○町1-2-3 ○○市○○町1-2-3 のように、入力した人や時期(市町村統合前の状態)によって形式が違います。 「○○町」の部分を使って並び替えをするために、ユーザー設定リストで、町名リストを北から南の町名順で作成してそれを使って並び替えをしてみましたが、上手く反映しません。 ユーザー設定リストの作り方や、マクロの組み方があれば教えていただけないでしょうか?

  • excelのピボットテーブルに並び替えについて

    画像のようなピボットテーブルを作成しようと思っています。 そこで、毎月最終月(今回の例だと9月)の数値順にAさん・Bさん・Cさんを並び替えを行いたいと思いますが、どうしても総計で並び替えがかかってしまいます。 どのようにすれば最終月で並び替えをすることができるのでしょうか? ちなみにexcelは2010です。 よろしくお願いします。

  • データの並び替え方法について

    データの並び替えについて 【リストA】 顧客番号,氏名,データ1,データ2,データ3,データ4, 0001,鈴木 一郎, 1, 12, 45, 6 0002,山田 太郎, 12, 345, 67, 0 0003,大木 凡人, 20, 30, 40, 30 【リストB】 顧客番号,データ区分,数量 0001, 1, 1 0001, 2, 12 0001, 3, 45 0001, 4, 6 0002, 1, 12 0002, 2,345 0002, 3, 67 0002, 4, 0 0003, 1, 20 0003, 2, 30 0003, 3, 40 0003, 4, 30, 上記のようなリストAの形式からリストBに自動で変換する方法を教えてください EXCELでもACCESSでも簡単なやり方があればうれしいです よろしくお願いします

  • EXCELでデータの部分的並び替え

    EXCELでデータの部分的並び替え a 5 a 6 a 7 b 7 b 8 b 8 c 7 c 7 c 5 . . というデータがあって a,b,cそれぞれについて右の数字を並び替え最大値と 最小値を出すにはどのようにすればいいでしょうか マクロで書く必要がありますか よろしくお願いします

  • Excelでのデータの並び替え

    Excelで以下のようにデータの並び替えを行いたいのですが どのような関数や手順で行えばいいのでしょうか。 A  B           A   B  C  D 001 a           001  a  b 001 b       →   002  a  b  c 002 a       →   003  a 002 b       →   004  a  b 002 c       →   . 003 a           . 004 a           . 004 b           . .               . . . 上記のような感じで、A列の重複を省きB列のデータを1列ごとに表示したいのです。 宜しくお願いいたします。

専門家に質問してみよう