マンガでよめる痔のこと・薬のこと

C# shapes.AddPictureによるExcelファイルへの画像挿入。

現在、C#でExcelファイル(xls)にPNG画像を貼り付けるツールを作成しています。
以下のプログラムを実行したのですが、
shapes.AddPicture(@"C:\test.png", MsoTriState.msoFalse,MsoTriState.msoFalse,fx, fy, 100,100);
の部分で以下の様なエラーが表示されました。

----------------
エラー文
----------------
型 'System.Runtime.InteropServices.COMException' のハンドルされていない例外が mscorlib.dll で発生しました

追加情報: 指定された値は境界を超えています。
----------------

つきましては解決方法を教えてください。



-----------------------
プログラム
-----------------------
Excel.Application exApp = new Excel.Application();

Excel.Workbook wkbook;

Excel.Workbooks wkbooks = exApp.Workbooks;

exApp.Visible = true;

exApp.DisplayAlerts = false;

wkbook = (Excel.Workbook)wkbooks.Open(@"C:\test.xls", Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);

Excel.Sheets sheets = wkbook.Worksheets;

Excel.Worksheet wksheet = (Excel.Worksheet)sheets["test"];

Excel.Range cells = wksheet.Cells;

Excel.Range range = (Excel.Range)cells[1, 21];

range.Select();

Excel.Shapes shapes = wksheet.Shapes;
float fx = float.Parse(range.Left.ToString());

float fy = float.Parse(range.Top.ToString());

shapes.AddPicture(@"C:\test.png", MsoTriState.msoFalse,MsoTriState.msoFalse,fx, fy, 100,100);

-----------------------

このQ&Aに関連する最新のQ&A

A 回答 (1件)

> shapes.AddPicture(@"C:\test.png", MsoTriState.msoFalse,MsoTriState.msoFalse,fx, fy, 100,100);


第2引数(msoFalse→画像を直接貼り付ける)と第3引数(msoFalse→文書と共に画像を保存しない)とが矛盾しています。

リファレンスを参照して、適切な引数を設定してください。

参考URL:http://msdn.microsoft.com/ja-jp/library/microsof …
    • good
    • 0

このQ&Aに関連する人気のQ&A

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています

このQ&Aを見た人が検索しているワード

このQ&Aと関連する良く見られている質問

QC#でのExcel操作について.(Rangeオブジェクトへの複数範囲設定)

C#でExcelのグラフを作成させるプログラムを書いるのですが,Rangeオブジェクトへの離れたセルの複数範囲を指定したいのですが,いろいろ調べてみましたがどうしても解決できません.
調べた限りではVBではできるようですが,C#ではできないのでしょうか?

Excel.ChartObjects chartObjects =(Excel.ChartObjects)oSheet.ChartObjects(Type.Missing);
Excel.ChartObject chartObj = chartObjects.Add(100, 100, 700, 400);
Excel.Chart chart = chartObj.Chart;
Excel.Range chartRange = oSheet.get_Range("B1","B3");
/*↑の部分で("B1:B3,B5:B8,C5")のようなことをしたいです.RangeにAddメソッドのようなものがあればと思っているのですが無いみたいなので‥‥*/
chart.SetSourceData(chartRange,Excel.XlRowCol.xlColumns);
Excel.SeriesCollection seriesCollection=(Excel.SeriesCollection)chart.SeriesCollection(Type.Missing);

よろしくお願いします.

C#でExcelのグラフを作成させるプログラムを書いるのですが,Rangeオブジェクトへの離れたセルの複数範囲を指定したいのですが,いろいろ調べてみましたがどうしても解決できません.
調べた限りではVBではできるようですが,C#ではできないのでしょうか?

Excel.ChartObjects chartObjects =(Excel.ChartObjects)oSheet.ChartObjects(Type.Missing);
Excel.ChartObject chartObj = chartObjects.Add(100, 100, 700, 400);
Excel.Chart chart = chartObj.Chart;
Excel.Range chartRange = oSheet.get_Rang...続きを読む

Aベストアンサー

Excel.Range chartRange = oSheet.get_Range("B1:B3,B5:B8,C5", Missing.Value);
でよいのではないでしょうか?
(Missingは using System.Reflection)
(私はC#の知識は全くありませんがVC# 2005 Express Editionで確認しました)

参考URL:http://support.microsoft.com/default.aspx?scid=kb;ja;302096

QC#で画像を他の画像に貼り付けるには

C#でBitmap型の画像を他の画像の任意の位置に貼り付けるにはどうすれば良いのでしょうか?

Aベストアンサー

「他の画像」のImageからGraphicsを作り (Graphics.FromImage),
「貼り付けたい画像」 (=書き込みたい画像) を引数にDrawImageを呼び出す。

References)
http://msdn.microsoft.com/ja-jp/library/system.drawing.graphics.fromimage.aspx
http://msdn.microsoft.com/ja-jp/library/42807xh1.aspx

Qフルパスから最後のディレクトリ名を取得したい。

vb.netなのですが、例えば
c:\aaa\bbb\ccc\ddd\eee\fff.exe
というフルパスがあったとして、
eeeというディレクトリ名を取得したいのですが、
何か良い方法はないでしょうか。
それぞれのディレクトリ名の文字数や階層数は
決まっていないのですが、オススメの方法が
ありましたら、教えて頂けると助かります。

Aベストアンサー

MessageBox.Show(IO.Path.GetFileName(IO.Path.GetDirectoryName(myPath)))

IO.Path の GetDirectoryName でフォルダのフルパスを取得して、さらに IO.Path の GetFileName で最終フォルダ(またはファイル)の名前を取得。

QC# インスタンスの破棄

C#でインスタンスの破棄を明示的に行いたいのですが、
実際の開発現場では、どのように行っているのでしょうか?

自分で調べると「ガベージコレクタ」が暗黙的に行っているようですが明示的には行わないのが普通なのでしょうか?
もしくは、「Dispose」を使用して明示的に行うのが普通なのでしょうか?

実際に開発されている方からすると簡単な事かもしれませんが教えて頂けると助かります。

以上ですが、よろしくお願いいたします。

Aベストアンサー

結論から言うと、どちらでも良いです。
できれば生成から破棄まで考えて開発できると良いですね。

ガベージコレクションが実行されることで自動開放されますから、
一切.close()や.dispose()を使わなかったとしてもプログラムが
不正終了してしまう事はほとんどありません。

実際の開発では使わなくなったものを使わなくなった時点で
明示的に破棄することが多いです。正確には明示的に破棄するもの、
明示的に破棄しないもの、の2種類に分類しています。

例えばファイルを読み書きするストリーム系のオブジェクトや
データベースとのコネクションなどです。これは開発会社や
開発チーム、案件によって若干違っていて、徹底するところや
適当なところもあります。個人的には徹底したい派ですが。。。

ガベージコレクションが発生するとプログラムの実行動作が
遅くなり、また瞬間的に大きな負担がかかることがあります。
そのため全てをガベージコレクタに任せるのではなく、
明示的に開放できるもの、メモリを大量に消費するものは
その都度、適切に開放していくことで処理効率が良くなります。

プログラミング関連の調べ物で、サンプルソース等を見ることが
あるかと思います。この時サンプルで明示的に開放していたら、
それは明示的に開放したほうが良いもの、と思いましょう。
これだけでもステップアップになりますね。

結論から言うと、どちらでも良いです。
できれば生成から破棄まで考えて開発できると良いですね。

ガベージコレクションが実行されることで自動開放されますから、
一切.close()や.dispose()を使わなかったとしてもプログラムが
不正終了してしまう事はほとんどありません。

実際の開発では使わなくなったものを使わなくなった時点で
明示的に破棄することが多いです。正確には明示的に破棄するもの、
明示的に破棄しないもの、の2種類に分類しています。

例えばファイルを読み書きするストリーム...続きを読む

QDataTableから条件を満たした行を別のDatatableへコピーしたい

VC#2005とSQLServer2005ExpressEditionでWindowsアプリケーションを作成しています。

データベースの中から1つのマスタテーブルのデータを呼び出すのにTableAdapterを使ってDataTableにデータをバインドしました。
そこから条件を満たしている行をすべて抽出して同じ型のDataTableにデータをコピーしたいのです。

ですから、DataTableは2つ用意しています。1つは上記の通りデータをバインドしていますが、もう1つは宣言しただけなのでまだ空っぽの状態です。
DataTableにはカラムが3列あり、その中の1列をグループIDとしています。
条件としてはグループIDが同じであるということです。
やりたいことは条件を満たしている行をすべて抽出して空のデータテーブルにコピーすることです。

どなたかご存知の方いらっしゃれば教えてください。
よろしくお願いします。

Aベストアンサー

C#だったんですね … さほど変わりないと思いますが

お使いのコードが提示されていないのでこちらで適当な変数をでっち上げております
現在お使いのコードを支障の無い範囲で提示しましょう

//元のデータテーブルがdtSourceとすると
// テーブル構造をコピー
DataTable dt = dtSource.Clone();
DataRow r = null;
foreach( DataRow dtRow in dtSource.Select("選択するための文字列"))
{
  r = dt.NewRow();
  for( int n = 0; n < dtRow.ItemArray.Length; n++ )
  {
    r[n] = dtRow[n];
  }
  dt.Rows.Add( r );
}
といった具合になると思います

# 前回の投稿中のstSorceはdtSourceの単なるミスです

QEXCELにクリップボードにある画像を貼り付け、その表示サイズを変更したい

現在、VBからEXCELを起動し、その起動したEXCELにクリップボード経由で画像を貼り付け、その画像の表示サイズを変更したいと考えているのですが、やり方が分かりません。
もし、ご存じの方がいらっしゃいましたら教えて頂けませんでしょうか。

よろしくお願い致します。

Aベストアンサー

マクロの使い方を知っていれば
VBAで記述されるので参考になりますよ。

実際にやりたいことをマクロに記録して
マクロをコードで見てみては?

QC#で共有変数の定義をするには

C#で共有変数の定義をするには、どうしたらよいでしょうか。具体的には、起動パラメータで、任意の文字列(3~4バイト)を渡して、C#アプリケーションを、起動し、プログラムの任意の場所で、そのパラメータを参照したいと考えています。起動パラメータの受け取りは、できるのですが、そのパラメータを、プログラムのどこからも参照できる領域(ここの定義方法が不明)に格納するには、どうしたらよいでしょうか。(2重起動を許す前提です。実行時に1つの目のプログラムにはパラメータ"XYZ"を渡し、2つ目のプログラムを起動時にはパラメータ"ABCD"を渡し、その値により、プログラムの動作を制御したいと思っています)
Windows-xp visual-studio2008 C#でwindowsアプリケーションを作成しています。

Aベストアンサー

namespace test1
{
  static class Program
  {
    /// <summary>
    /// アプリケーションのメイン エントリ ポイントです。
    /// </summary>
    [STAThread]
    static void Main(string[] args)
    {
      if (args.Length > 0)
      {
        strArg = args[0];
      }
      Application.EnableVisualStyles();
      Application.SetCompatibleTextRenderingDefault(false);
      Application.Run(new Form1());
    }
    // ここに記述
    static public string strArg = null;
  }
}

メインクラスのメンバーとしてスコープが有効な場所に記述します

namespace test1
{
  static class Program
  {
    /// <summary>
    /// アプリケーションのメイン エントリ ポイントです。
    /// </summary>
    [STAThread]
    static void Main(string[] args)
    {
      if (args.Length > 0)
      {
        strArg = args[0];
      }
      Application.EnableVisualStyles();
      Application.SetCompatibleTextRenderingDefault(false);
      Application.Run(n...続きを読む

QC#でフォームのオブジェクト名を変数名で指定

C#でフォームのオブジェクトを変数名で指定するにはどうしたらよいでしょうか?

例えば、フォームにラジオボタンrdo0~rdo9と、
それぞれに対応するテキストボックスtxt0~txt9が用意されている状態で、
rdo1がチェックされていたらtxt1に"OK"と表示、
rdo2がチェックされていたらtxt2に"OK"と表示・・・
といったことをfor文で実現する場合どのようにしたらよいでしょうか?
変数をオブジェクト名として認識させるための方法がわかりません。

どなたかご教授願います。


*********************************************
for(int i=0;i<10;i++)
{
 rdoname = "rdo" + i;
 txtname = "txt" + i;

 if((何らかの処理?)(rdoname).checked)
  (何らかの処理?)(txtname).txt = "OK";
}

****************************************
↑この、オブジェクトとして認識する為の「何らかの処理」部がわかりません。

C#でフォームのオブジェクトを変数名で指定するにはどうしたらよいでしょうか?

例えば、フォームにラジオボタンrdo0~rdo9と、
それぞれに対応するテキストボックスtxt0~txt9が用意されている状態で、
rdo1がチェックされていたらtxt1に"OK"と表示、
rdo2がチェックされていたらtxt2に"OK"と表示・・・
といったことをfor文で実現する場合どのようにしたらよいでしょうか?
変数をオブジェクト名として認識させるための方法がわかりません。

どなたかご教授願います。


************************...続きを読む

Aベストアンサー

参考URL参照。

参考URL:http://dobon.net/vb/dotnet/control/findcontrolbyname.html

QC#で画像をクリップボードへのコピーと貼り付けについて

GraphicsオブジェクトのDrawImageメソッドを使って画像を表示させています。
この画像をクリップボードへコピーしてほかのところに貼り付けしたいのですが、クリップボードへはClipboard.SetDataObject()を使用すればよいと思っています。
しかし、どのように使ったらいいのかよくわかりません。現在のソースは以下のようになっています。
//Bitmapオブジェクトの作成(画像ファイルを読み込む)
Bitmap bmap = new Bitmap(@"C:\test2.bmp");
//元の画像からの切り取り範囲の指定
RectangleF rectSrc = new RectangleF                 (pointX,pointY,WidthX,WidthY);
//貼り付け先を指定範囲の指定
RectangleF rectDst =
new RectangleF(0, 0, DstX,DstY);
//PictureBox1のGraphicsオブジェクトの作成
Graphics g= pictureBox1.CreateGraphics();
//画像の描画
g.DrawImage(bmap, rectDst,rectSrc,GraphicsUnit.Pixel);
//クリップボードへのコピー
Clipboard.SetDataObject(g);
よろしくおねがいいたします。

GraphicsオブジェクトのDrawImageメソッドを使って画像を表示させています。
この画像をクリップボードへコピーしてほかのところに貼り付けしたいのですが、クリップボードへはClipboard.SetDataObject()を使用すればよいと思っています。
しかし、どのように使ったらいいのかよくわかりません。現在のソースは以下のようになっています。
//Bitmapオブジェクトの作成(画像ファイルを読み込む)
Bitmap bmap = new Bitmap(@"C:\test2.bmp");
//元の画像からの切り取り範囲の指定
RectangleF rectSrc = ...続きを読む

Aベストアンサー

Bitmap bmp = new Bitmap("C:\\test2.bmp");

RectangleF rectDst =
new RectangleF(0, 0, bmp.Width ,bmp.Height);

Clipboard.SetDataObject(
bmp.Clone(rectDst, bmp.PixelFormat) , true);

// Clipboard.SetDataObject(bmp,true);

QC#にて別クラスの関数を使いたい

C#にて、別クラスの関数を使用する方法を教えてほしいです。

下記のような、構造体を受け取るメソッドを作りました。

*****************************
private struct MyPoint
{
public int x;
public int y;
}

private void proc1(MyPoint pt)
{
MessageBox.Show("座標:" ; pt.x + "," + pt.y + "実行結果");
}

private void button1_Click(object sender ,System.EventArgs e)
{

MyPoint pt;
pt.x = 10;
pt.y = 20;
proc(pt);
}
*****************************

別のフォームのクラスから、proc1を呼び出したいのですが、やり方がわかりません。
どうか、教えてください。

Aベストアンサー

同じ定義をしたとしても別の名前空間に書いた構造体は同一とはみなされません。

呼び出し先クラスでの構造体を private では無く、public で宣言して下さい。

呼び出し元では、

MyClass.MyPoint pt;

のようにして実体を作ります。


このQ&Aを見た人がよく見るQ&A

人気Q&Aランキング

おすすめ情報