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

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

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

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

Q&A

1回答

6175閲覧

PowerShell: Excelシートの最終行・列を取得したい。正確に!

退会済みユーザー

退会済みユーザー

総合スコア0

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

0グッド

1クリップ

投稿2016/03/12 07:58

編集2022/01/12 10:55

皆様、宜しくお願い致します。

###前提・実現したいこと

タイトル通りです。
エクセルシート上の利用済み範囲の
最終行と最終列を取得したい。

###発生している問題・エラーメッセージ

1-3行程度、ずれる。(取りこぼす)
Rowに+3とかすると、取りこぼさずに取得できました。

###方式

どちらも、取りこぼす。。。

.Cells.SpecialCells(11) #または。 .UsedRange.Rows.Count

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

Name Value


PSVersion 5.0.10586.63
PSCompatibleVersions {1.0, 2.0, 3.0, 4.0...}
BuildVersion 10.0.10586.63
CLRVersion 4.0.30319.42000
WSManStackVersion 3.0
PSRemotingProtocolVersion 2.3
SerializationVersion 1.1.0.1

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

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

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

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

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

ogaaaan

2016/03/14 00:59

『タイトル通りです。』←タイトルおかしいです。全角やめましょう。あとスペルミスも修正で。
ogaaaan

2016/03/14 01:21

『仕様書のような(間違った使い方をした)形式』← 誰もこの仕様書を知らないし、間違った使い方といわれても意味がわかりません。『恐らくサンプリングデータな為、根拠はないです。』← 元のデータがわからないので何を言っているのか不明です。まずは質問内容を他人が見てもわかるように修正する必要がありますね。
退会済みユーザー

退会済みユーザー

2016/03/14 03:16 編集

コメントありがとうございます。 次回は、質問文章の添削ではなく、疑問点の解決につながるコメントか、 解決策そのものをコメントいただけると幸いです。
ogaaaan

2016/03/14 03:24

この場所は情報の修正依頼の場所なんで別に問題ないと思うけどどうでしょ。 わかりやすい文章のほうが回答とかヒントたくさんもらえると思うので。
退会済みユーザー

退会済みユーザー

2016/03/14 04:06

コメントありがとうございます。 解決策、または関連情報をお持ちで、 それの適用度や確度を向上させる為の内容、それを裏づける為に必要な内容でしたら、 謹んで対応致します。
ogaaaan

2016/03/14 04:11

そうですか。回答者が現れるのを願ってます。
退会済みユーザー

退会済みユーザー

2016/03/14 04:29

この度は、貴重なお時間、ご意見賜りまして、ありがとうございました。
guest

回答1

0

前段であるWorkSheet取得、アクティベートまでは省きます。
.Cells.SpecialCells(11)で参照する前に下記を入れてみてください。

$ws.UsedRange.Select()

真偽値が返ってくるので変数にでもいれてください。
あとは.Row .Columnで参照できると思います。

スキルを拝見したところVBAとございましたのでUsedRangeの説明は省きますが
VBAからPSに落とし込んでいただいたほうがより理解が深まりそうです。

どうぞよろしくお願いいたします。

投稿2016/03/14 10:10

y.o

総合スコア27

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

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

退会済みユーザー

退会済みユーザー

2016/04/19 01:23 編集

コメントありがとうございます。 一度試してみます。結果はまた改めて。 ---2016.04.19 追記 効果はありませんでした。 逆に、書式設定されただけの見た目は空白のセルを参照して、 nullが返ってきて、、、結局、この処理は外しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問