• ベストアンサー

Excelで結合されたセルの幅を自動調整したい

こんにちわ。 早速ですが質問させてください。 現在、Excelにて書類を作成しております。 作成した書類は原版を取っておき、使いまわす予定です。 書類のある項目欄につきまして、4つの列が結合された項目で、Wordやメールなどからコピー&ペーストします。 しかし、貼り付けると、「文章が長い場合」、あるいは「改行が多い場合」、行の幅が変わらないので1行目以降が途切れてしまい、毎回手動で列の幅を調節しております。 この列の幅の調節をマクロや関数を用いて自動でできないでしょうか。 何卒、ご教授のほど宜しくお願いいたします。

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

  • ベストアンサー
  • nda23
  • ベストアンサー率54% (777/1415)
回答No.6

#2です。 行の高さは1行の高さの行数倍でよいはずなので、 文字列中の改行の個数(末尾は除く)を数えれば 1行しかないと分かっている行の高さに改行の 個数を掛けて求められます。 最後の改行を抜いたのは最下段に空行ができる ことを防ぐためですが、それも必要ならば、その 処理は飛ばしてください。 プログラム例 Dim 末尾改行削除 As Object Dim 改行カウント As Object Dim 単一行の高さ As Double Function 行高算出(ByVal 文字列 As String) As Double If 改行カウント Is Nothing Then     '正規表現が作成されていない場合は作成する     Set 末尾改行削除 = CreateObject("VBScript.RegExp")     末尾改行削除.Global = False     末尾改行削除.Pattern = "(\r{0,1}\n)$"     Set 改行カウント = CreateObject("VBScript.RegExp")     改行カウント.Global = True     改行カウント.Pattern = "(\r{0,1}\n)"     '1行と分かっているセルの高さを記録     単一行の高さ = Cells(1,1).RowHeight '★実情に合わせる End IF 文字列 = 末尾改行削除.Replace(文字列, "") 行高算出 = (改行カウント.Execute(文字列).Count + 1) _       * 単一行の高さ End Function (1)正規表現を使って、文字列最後の改行のみ除去します。  標準のReplace関数では「最後だけ除去」ができません。 (2)正規表現を使って、文字列中の改行の集合を作成し、  その個数+1に単一行の高さを掛けて計算しています。 ※正規表現は下記URL参照 http://msdn.microsoft.com/ja-jp/library/cc392487.aspx 【使用例】 高さ = 行高算出(出力文) Cells(行, 列).RowHeight = 高さ Cells(行, 列).Value = 出力文 尚、ByValオプションなので、上記出力文の末尾に改行が ある場合は高さとしては最後の空行は入りません。 但し、データとしては最後の改行は残っています。

その他の回答 (5)

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

意外に過去に似た件で質問紙って居る人が居ます。 Googleで「セル結合AutoFit」で照会すると、高さが調節されないと言う苦情がでてます。 ついでに読んでください。 http://sonic64.com/2005-04-26.html  など マクロも載っている。 === エクセルのセル結合は色々な処理(特にVBAで)非常に複雑化する。仕様的に発達途中かもしれない。 出来るだけ使わないことだ。

  • end-u
  • ベストアンサー率79% (496/625)
回答No.4

簡易的な手法としては 結合解除→範囲内で中央→AutoFit→再結合 ..が使えます。 With Selection   .UnMerge   .VerticalAlignment = xlTop   .HorizontalAlignment = xlCenterAcrossSelection   .WrapText = True   .EntireRow.AutoFit   .Merge across:=True   .HorizontalAlignment = xlLeft End With 固定範囲の場合は With Sheets("Sheet1").("A1:D10") ..などと指定すれば良いです。

  • acha51
  • ベストアンサー率41% (436/1042)
回答No.3

回答にはなりませんが、見落とす失敗を防ぐなら、以下の姑息な手段でどうでしょう セルの書式設定⇒配置タブの縮小して全体を表示するにチェックを入れる 文字サイズが変わるのでセル幅を調整する。 結局はプレビューで確認が必要ですが。

  • nda23
  • ベストアンサー率54% (777/1415)
回答No.2

結合したセルの場合、AutoFitメソッド、 WrapTextプロパティでの自動調整は 出来ないようです。 高さの調整は見えない所にある結合 されていないセルに内容をコピーして WrapTexをTrueにした時のRowHeight プロパティを目的の行の同プロパティに 設定すれば何とかなるでしょう。 幅の場合は同じくお試しセルにある EntireColumnオブジェクトにAutoFit メソッドを実行し、ColumnWidthを参照 すれば幅は分かります。しかし、これは トータルの幅なので、どの列にどの位の 幅を割りふるかが解決できません。 尚、文中に「幅」と出てきますが、「高さ」 と区別されていないような気がします。 幅と高さでは扱うオブジェクト、プロパティ、 メソッドが違いますので、明示的に区別 してください。

guren314
質問者

お礼

ご解答ありがとうございます。 なるほど、やはり、別の箇所へ貼り付けて行高さを参照する方法が良いでしょうか・・・。 列の結合は固定のため、別の箇所の列幅を予め合わせておけば問題なさそうですので、試してみます。

guren314
質問者

補足

ご指摘ありがとうございます。 すみません、以下のように質問内容を修正します。 しかし、貼り付けると、「文章が長い場合」、あるいは「改行が多い場合」、行の<高さ>が変わらないので1行目以降が途切れてしまい、毎回手動で<行>の<高さ>を調節しております。 この<行>の<高さ>の調節をマクロや関数を用いて自動でできないでしょうか。

noname#131542
noname#131542
回答No.1

Sub a() Columns("a:z").AutoFit rows(1:50).autofit End Sub columns の使い方はa-zの列の幅 調節 rows   の使い方は行の高さ 調節

guren314
質問者

お礼

ご解答ありがとうございます。 早速試してみましたが、申し訳ありません、調節できませんでした。 恐らく、セルが結合されているためと思われるのですが、単に理解していないだけかもしれません。 列A,B,Cが結合されている(A,1)セルの幅を調整する場合、rows("1:1").autofitで良いのでしょうか?

関連するQ&A

  • エクセル行の幅自動調整の方法

    エクセルは、行幅や列幅を全選択した後、列の境目をクリックすると、行の場合は、一行の幅に自動調整されます。 しかし、セルの中で改行した場合でも、一行の幅に調整されてしまいます。 セル内の改行でも、改行文の行幅に自動調整する方法はありますでしょうか。 ご存知の方がおられましたら教えてください。 よろしくお願いいたします。

  • エクセルで結合したセルの高さの自動調整方法?

    エクセル2000、Win2000です。 いくつかのセルを横に結合し、セル内で「折り返して全体を表示する」にしています。 セルを結合してない場合は、入力文字数が多くなっても行の高さを自動調整にすれば、ちゃんと折り返して全部表示されますが、結合したセルの場合は、自動調整がきかず、 いちいち手動で調整しなくてはいけません。 1.結合セルでも自動調整する方法はないですか? 2.ない場合、VBAで行の高さを変えてみようと思いますが、セル内で折り返しているかどうか、および何行に折り返されているかはどう判別すればいいでしょうか?

  • 【エクセル】自動で、同じ内容のセルを結合させたい。

    ある縦1列に(A01が5行、A02が8行・・・ G32が4行といったように)規則的に 並んでいる複数の分類番号があるとして、 これら同じ分類番号を見やすくするために、 今は一つ一つ手動でセル結合しています。 もし、自動的に、同じ分類番号を一つのセルに 結合してくれるようなやり方があったら・・・ と思うのですが、何かお知恵を拝借できないでしょうか?

  • エクセルの長文が入った結合セルを自動調整する方法

    金額等を書いた見積書作成でエクセルを利用しています。 症状などの症状を記入している結合されたセルの部分があるのですが、かなりの長文が入っている場合に、一番左の行の自動調節目的で行と行の間の線をダブルクリックしても、その長文の頭の1行部分しか表示できません。 その下の長文部分もきれいに表示してくれるような機能はエクセルにありますでしょうか? どうぞ、ご教示の程よろしくお願いします。

  • エクセルでセルの列、幅の調整

    OS:XP Pro Excel Ver:2007 エクセルでとあるシートを作成中なのですが、 A列、幅:2.86(塗りつぶし) B列、幅:8.86(空白) C列、幅:0.33(塗りつぶし) D列、幅:8.86(空白) E列、幅:0.33(塗りつぶし)  ・  ・  ・ と言う風にして表を作りたいのですが、 2.86が2.88、8.86が8.88、0.33が0.31と強制的に修正されてしまいます。 行に指定した数値は修正されずに変更出来るのですが、、、。 幅を任意の幅で使用することは出来ないのでしょうか?

  • 結合セルでの行の高さの自動調整

    エクセルでの質問です。 結合セルに折り返して表示の設定がしてあり、文章が入力されています。入力方法が統一されていないため、セルによって、一行だったり、長文だったり、セル内で改行して箇条書きで入力されていたりします。 文章の下が切れてしまうセルがあるので、手作業で行の高さを広げています。行数が何百行もあったりするのでとても手間と時間がかかってしまいます。いい方法がないかと、“マクロでセル内の文字数が50以上なら行の高さを30にする”としてみたのですが、箇条書きのセルだとうまくいきません。そこで、“セル内に3行以上なら、行の高さを30 とする”というように行数を数えることは可能でしょうか? また、他に良い方法があれば教えてください。宜しくお願いします。

  • EXCELで結合された行幅の一括コピー

    初心者です。 EXCELで結合されたセルの行幅をしたの行にコピーすることはできますでしょうか? 例:A列→123が結合 B列→123結合なし 行をコピーして貼り付けようとしたのですが、 結合されたセルの一部を変更する事はできませんとのエラーがでます。 よろしくお願いします。

  • Excelでセル内改行

    お世話になります。 早速ですがExcelで複数のセルに文字列が入力されている時、それらの文字を結合する場合はCONCATENATE関数を使いますよね? で、この応用(なのか判りませんが)で例えばセルA1に"改"の文字が、セルB1には"行"の文字が入っているとき、セルC1に 改 行 と改行させて2行で表示したいのですが、セルC1に"=CONCATENATE(A1,CHAR(13),B1)"とやってもうまくいきませんでした。 Alt+Enterで手入力する以外に関数、マクロ等で何かいい方法がありますか? よろしくお願いします。

  • エクセルでセルの結合について

    Excel2000を使用してます。 A列B列C列に入力した文字をD列に全て表示させたく、 下記のようにしました。   A列  B列  C列   D列     あ   い    う    あいう(計算式を=A1&B1&C1)   か   き    く    かきく(計算式を=A2&B2&C2)   上記のように、計算式を入れて希望通りの文字表示は 出来るんですが、それをメモ帳などにペーストすると "あいう" "かきく" のように"が入ってしまいます。 置換によって取ろうとしますが、エクセル上では該当がありませんとなります。 メモ帳に一旦ペーストして置換すると、”は取れますが、 横列も長い為エクセルにペーストし直すと、一つのセルに入らず、 複数の行に分かれてしまいます。 ””が入らずに、一つのセルに結合の値を出すには どうしたらよいのでしょうか?

  • Excel マクロ 条件によるセルの結合

    テキストだとわかり辛いと思い、 画像を添付させていただきました。 3列の表があり、 A列に1~10までの数字(グループ名)を入力します。 これを、A列の数字が同じ場合、 B列とC列をセル結合したいのですが、 マクロで実現できるでしょうか? (行数は15行くらいあり毎日変わります) (最終行の次の行は空白です) (A列は結合してもしなくても問題ありません) Excel 2007 Windows10を使用しています。 おわかりの方がいらっしゃいましたら、 どうぞよろしくお願い致します。

専門家に質問してみよう