0

ここに私のケースがあります: データベースからデータを取得できますが、プログラムを実行してQuantity列 (3 行目) を埋めると、次のエラーが表示されます: index was out of range. なぜこれが起こるのか知っている人はいますか?( Quantity列 (3 行目) を入力しようとすると、エラーが表示されます) <-- 下の図に示されています。

ここに私のプログラムの画像があります: *Quantity* 列 (3 行目) を入力しようとすると、エラーが表示されました

エラーが指摘されている場所の画像は次のとおりです。 ここに画像の説明を入力

完全なコードは次のとおりです。

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.OleDb;
using System.Drawing;
using System.Linq;
using System.Security.Principal;
using System.Text;
using System.Windows.Forms;

namespace Sell_System
{
    public partial class Form2 : Form
    {
        string connectionString = (@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=\Archives\Projects\Program\Sell System\Sell System\App_Data\db1.accdb;Persist Security Info=False;");
        private Form1 firstForm;
        private List<List<TextBox>> textBoxCodeContainer = new List<List<TextBox>>();
        private List<List<TextBox>> textBoxQuantityContainer = new List<List<TextBox>>();
        private List<List<TextBox>> textBoxDescContainer = new List<List<TextBox>>();
        private List<List<TextBox>> textBoxSubTotalContainer = new List<List<TextBox>>();
        private List<List<TextBox>> textBoxTotalContainer = new List<List<TextBox>>();
        private List<List<TextBox>> textBoxAllTotalContainer = new List<List<TextBox>>();

        public Form2()
        {
            InitializeComponent();
        }

        public Form2(Form1 firstForm)
            : this()
        {
            this.firstForm = firstForm;
        }

        private void Form2_Load(object sender, EventArgs e)
        {
            UpdateTextPosition();

            OleDbDataReader dReader;
            OleDbConnection conn = new OleDbConnection(connectionString);
            conn.Open();
            OleDbCommand cmd = new OleDbCommand("SELECT [Code] FROM [Data]", conn);

            dReader = cmd.ExecuteReader();

            AutoCompleteStringCollection codesCollection = new AutoCompleteStringCollection();

            while (dReader.Read())
            {
                string numString = dReader[0].ToString().PadLeft(4, '0');
                codesCollection.Add(numString);
            }

            dReader.Close();
            conn.Close();

            if (firstForm.comboBox1.SelectedIndex == 0)
            {
                label1.Text = "Code:";
                label1.Location = new Point(60, 125);
                label2.Text = "Welcome to the Selling System.";
                label2.Location = new Point(600, 0);
                label3.Text = "Quantity:";
                label3.Location = new Point(155, 125);
                label4.Text = "Description:";
                label4.Location = new Point(580, 125);
                label5.Text = "Sub Total on Rp:";
                label5.Location = new Point(1020, 125);
                label6.Text = "Total on Rp:";
                label6.Location = new Point(1210, 125);
                label7.Text = "Total on Rp:";
                label7.Location = new Point(1080, 580);
            }

            else if (firstForm.comboBox1.SelectedIndex == 1)
            {
                label1.Text = "Kode:";
                label1.Location = new Point(60, 125);
                label2.Text = "Selamat datang di Selling System.";
                label2.Location = new Point(600, 0);
                label3.Text = "Banyaknya:";
                label3.Location = new Point(145, 125);
                label4.Text = "Keterangan:";
                label4.Location = new Point(580, 125);
                label5.Text = "Sub Total di Rp:";
                label5.Location = new Point(1020, 125);
                label6.Text = "Total di Rp:";
                label6.Location = new Point(1210, 125);
                label7.Text = "Total di Rp:";
                label7.Location = new Point(1080, 580);
            }

            //****TextBox for Code****
            for (int y = 0; y <= 16; y++)
            {
                textBoxCodeContainer.Add(new List<TextBox>());
                textBoxCodeContainer[0].Add(new TextBox());
                textBoxCodeContainer[0][y].Size = new Size(100, 50);
                textBoxCodeContainer[0][y].Location = new Point(25, 150 + (y * 25));
                textBoxCodeContainer[0][y].TextChanged += new System.EventHandler(this.textBox_TextChanged);

                textBoxCodeContainer[0][y].AutoCompleteMode = AutoCompleteMode.Suggest;
                textBoxCodeContainer[0][y].AutoCompleteSource = AutoCompleteSource.CustomSource;
                textBoxCodeContainer[0][y].AutoCompleteCustomSource = codesCollection;

                Controls.Add(textBoxCodeContainer[0][y]);
            }

            //****TextBox for Quantity****
            for (int y = 0; y <= 16; y++)
            {
                textBoxQuantityContainer.Add(new List<TextBox>());
                textBoxQuantityContainer[0].Add(new TextBox());
                textBoxQuantityContainer[0][y].Size = new Size(100, 50);
                textBoxQuantityContainer[0][y].Location = new Point(125, 150 + (y * 25));
                textBoxQuantityContainer[0][y].TextChanged += new System.EventHandler(this.textBox_TextChanged);

                Controls.Add(textBoxQuantityContainer[0][y]);
            }

            //****TextBox for Description****
            for (int y = 0; y <= 16; y++)
            {
                textBoxDescContainer.Add(new List<TextBox>());
                textBoxDescContainer[0].Add(new TextBox());
                textBoxDescContainer[0][y].Size = new Size(750, 50);
                textBoxDescContainer[0][y].Location = new Point(225, 150 + (y * 25));

                Controls.Add(textBoxDescContainer[0][y]);
            }

            //****TextBox for Sub Total****
            for (int y = 0; y <= 16; y++)
            {
                textBoxSubTotalContainer.Add(new List<TextBox>());
                textBoxSubTotalContainer[0].Add(new TextBox());
                textBoxSubTotalContainer[0][y].Size = new Size(175, 50);
                textBoxSubTotalContainer[0][y].Location = new Point(975, 150 + (y * 25));

                Controls.Add(textBoxSubTotalContainer[0][y]);
            }

            //****TextBox for Total****
            for (int y = 0; y <= 16; y++)
            {
                textBoxTotalContainer.Add(new List<TextBox>());
                textBoxTotalContainer[0].Add(new TextBox());
                textBoxTotalContainer[0][y].Size = new Size(175, 50);
                textBoxTotalContainer[0][y].Location = new Point(1150, 150 + (y * 25));
                textBoxTotalContainer[0][y].TextChanged += new System.EventHandler(this.textBox_TextChanged);

                Controls.Add(textBoxTotalContainer[0][y]);
            }

//****TextBox for Total All****
            textBoxAllTotalContainer.Size = new Size(175, 50);
            textBoxAllTotalContainer.Location = new Point(1150, 575);
            textBoxAllTotalContainer.TextChanged += new System.EventHandler(this.textBox_TextChanged);

            Controls.Add(textBoxAllTotalContainer);

        }

        private void UpdateTextPosition()
        {
            Graphics g = this.CreateGraphics();
            Double startingPoint = (this.Width / 2) - (g.MeasureString(this.Text.Trim(), this.Font).Width / 2);
            Double widthOfASpace = g.MeasureString(" ", this.Font).Width;
            String tmp = " ";
            Double tmpWidth = 0;

            while ((tmpWidth + widthOfASpace) < startingPoint)
            {
                tmp += " ";
                tmpWidth += widthOfASpace;
            }

            this.Text = tmp + this.Text.Trim();
        }

        private void UpdateDatas()
        {
            int codeValue = 0;
            int index = 0;

            string query = "SELECT [Description], [Price] FROM [Data] WHERE [Code] IN (";

            OleDbDataReader dReader;
            OleDbConnection conn = new OleDbConnection(connectionString);
            conn.Open();

            if (int.TryParse(this.textBoxCodeContainer[0][0].Text, out codeValue))
            {
                query = query + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][1].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][2].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][3].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][4].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][5].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][6].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][7].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][8].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][9].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][10].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][11].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][12].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][13].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][14].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][15].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            if (int.TryParse(this.textBoxCodeContainer[0][16].Text, out codeValue))
            {
                query = query + "," + codeValue.ToString();
            }

            query = query + ")";

            OleDbCommand cmd = new OleDbCommand(query, conn);

            cmd.Parameters.Add("Code", System.Data.OleDb.OleDbType.Integer);

            dReader = cmd.ExecuteReader();

            while (dReader.Read())
            {
                if (textBoxCodeContainer[0][index].TextLength != 0)
                {
                    this.textBoxDescContainer[0][index].Text = dReader["Description"].ToString();
                    this.textBoxSubTotalContainer[0][index].Text = dReader["Price"].ToString();
                }

                index += 1;
            }

            dReader.Close();
            conn.Close();
        }

        private void UpdatePrice()
        {
            if (textBoxQuantityContainer[0][0].Text == "")
            {
                textBoxTotalContainer[0][0].Text = "";
            }

            else if (textBoxQuantityContainer[0][0].Text == "1")
            {
                textBoxTotalContainer[0][0].Text = textBoxSubTotalContainer[0][0].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][0].Text;
            }

            if (textBoxQuantityContainer[0][1].Text == "")
            {
                textBoxTotalContainer[0][1].Text = "";
            }

            else if (textBoxQuantityContainer[0][1].Text == "1")
            {
                textBoxTotalContainer[0][1].Text = textBoxSubTotalContainer[0][1].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][1].Text;
            }

            if (textBoxQuantityContainer[0][2].Text == "")
            {
                textBoxTotalContainer[0][2].Text = "";
            }

            else if (textBoxQuantityContainer[0][2].Text == "1")
            {
                textBoxTotalContainer[0][2].Text = textBoxSubTotalContainer[0][2].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][2].Text;
            }

            if (textBoxQuantityContainer[0][3].Text == "")
            {
                textBoxTotalContainer[0][3].Text = "";
            }

            else if (textBoxQuantityContainer[0][3].Text == "1")
            {
                textBoxTotalContainer[0][3].Text = textBoxSubTotalContainer[0][3].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][3].Text;
            }

            if (textBoxQuantityContainer[0][4].Text == "")
            {
                textBoxTotalContainer[0][4].Text = "";
            }

            else if (textBoxQuantityContainer[0][4].Text == "1")
            {
                textBoxTotalContainer[0][4].Text = textBoxSubTotalContainer[0][4].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][4].Text;
            }

            if (textBoxQuantityContainer[0][5].Text == "")
            {
                textBoxTotalContainer[0][5].Text = "";
            }

            else if (textBoxQuantityContainer[0][5].Text == "1")
            {
                textBoxTotalContainer[0][5].Text = textBoxSubTotalContainer[0][5].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][5].Text;
            }

            if (textBoxQuantityContainer[0][6].Text == "")
            {
                textBoxTotalContainer[0][6].Text = "";
            }

            else if (textBoxQuantityContainer[0][6].Text == "1")
            {
                textBoxTotalContainer[0][6].Text = textBoxSubTotalContainer[0][6].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][6].Text;
            }

            if (textBoxQuantityContainer[0][7].Text == "")
            {
                textBoxTotalContainer[0][7].Text = "";
            }

            else if (textBoxQuantityContainer[0][7].Text == "1")
            {
                textBoxTotalContainer[0][7].Text = textBoxSubTotalContainer[0][7].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][7].Text;
            }

            if (textBoxQuantityContainer[0][8].Text == "")
            {
                textBoxTotalContainer[0][8].Text = "";
            }

            else if (textBoxQuantityContainer[0][8].Text == "1")
            {
                textBoxTotalContainer[0][8].Text = textBoxSubTotalContainer[0][8].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][8].Text;
            }

            if (textBoxQuantityContainer[0][9].Text == "")
            {
                textBoxTotalContainer[0][9].Text = "";
            }

            else if (textBoxQuantityContainer[0][9].Text == "1")
            {
                textBoxTotalContainer[0][9].Text = textBoxSubTotalContainer[0][9].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][9].Text;
            }

            if (textBoxQuantityContainer[0][10].Text == "")
            {
                textBoxTotalContainer[0][10].Text = "";
            }

            else if (textBoxQuantityContainer[0][10].Text == "1")
            {
                textBoxTotalContainer[0][10].Text = textBoxSubTotalContainer[0][10].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][10].Text;
            }

            if (textBoxQuantityContainer[0][11].Text == "")
            {
                textBoxTotalContainer[0][11].Text = "";
            }

            else if (textBoxQuantityContainer[0][11].Text == "1")
            {
                textBoxTotalContainer[0][11].Text = textBoxSubTotalContainer[0][11].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][11].Text;
            }

            if (textBoxQuantityContainer[0][12].Text == "")
            {
                textBoxTotalContainer[0][12].Text = "";
            }

            else if (textBoxQuantityContainer[0][12].Text == "1")
            {
                textBoxTotalContainer[0][12].Text = textBoxSubTotalContainer[0][12].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][12].Text;
            }

            if (textBoxQuantityContainer[0][13].Text == "")
            {
                textBoxTotalContainer[0][13].Text = "";
            }

            else if (textBoxQuantityContainer[0][13].Text == "1")
            {
                textBoxTotalContainer[0][13].Text = textBoxSubTotalContainer[0][13].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][13].Text;
            }

            if (textBoxQuantityContainer[0][14].Text == "")
            {
                textBoxTotalContainer[0][14].Text = "";
            }

            else if (textBoxQuantityContainer[0][14].Text == "1")
            {
                textBoxTotalContainer[0][14].Text = textBoxSubTotalContainer[0][14].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][14].Text;
            }

            if (textBoxQuantityContainer[0][15].Text == "")
            {
                textBoxTotalContainer[0][15].Text = "";
            }

            else if (textBoxQuantityContainer[0][15].Text == "1")
            {
                textBoxTotalContainer[0][15].Text = textBoxSubTotalContainer[0][15].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][15].Text;
            }

            if (textBoxQuantityContainer[0][16].Text == "")
            {
                textBoxTotalContainer[0][16].Text = "";
            }

            else if (textBoxQuantityContainer[0][16].Text == "1")
            {
                textBoxTotalContainer[0][16].Text = textBoxSubTotalContainer[0][16].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][16].Text;
            }
        }

        private void textBox_TextChanged(object sender, EventArgs e)
        {
            UpdateDatas();
            UpdatePrice();
        }

    }
}

ここに私の問題があります: 「混乱しています。「textBoxAllTotalContainer.Text = textBoxTotalContainer[0][0].Text」に値を割り当てようとすると、コードは機能します。しかし、「textBoxAllTotalContainer.Text = textBoxTotalContainer[ 0][one(1)]"、画面が動かなくなった (Visual Studio からのデバッグを停止する必要がある)"

textBoxTotalContainer には 17 個のテキスト ボックスが含まれているため、[0][0] から [0][16] を使用し、textBoxAllTotalContainer には 1 つのテキスト ボックスが含まれているため、textBoxAllTotalContainer.Text を使用しました。

注:「キーワード(1)、それは「1」であると仮定します<--数字、(1)を書きました。[0] [(ここでは「1」であるはずです)]を変更しようとしたときに、テキストが自動的にリンク画像に変更しました」

問題: **"コードを試したとき

else if (textBoxQuantityContainer[0][0].Text == "1")
            {
                textBoxTotalContainer[0][0].Text = textBoxSubTotalContainer[0][0].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][0].Text;
            }

上記の画像では、 alltotalcontainerのテキストボックスがオン (Rp の合計、単語の後にテキストボックスがオン)、小計のテキストボックスがオン (Rp の小計) 、 totalcontainerのテキストボックスがオン(Rp の合計、テキストボックス)単語の下にあります)、quantitycontainerのテキストボックスは on (Quantity) です。上記のコードでは、 textboxtotalcontainer の textbox 1 がsubtotalcontainerの textbox 1 と同じであり、alltotalcontainerがtotalcontainerと同じであることを示しています。**

しかし、以下のコードでは機能せず、画面が動かなくなりました (Visual Studio で SHIFT + F5 を押さない限り、マウスが消えて何もできません):

else if (textBoxQuantityContainer[0][1].Text == "1")
            {
                textBoxTotalContainer[0][1].Text = textBoxSubTotalContainer[0][1].Text;
                textBoxAllTotalContainer.Text = textBoxTotalContainer[0][1].Text;
            }

ありがとう

4

2 に答える 2

1

コレクション内の存在しない要素にアクセスしようとすると、このエラーが発生します。

たとえば、文字列のリストがある場合...

List<string> myList = new List {"one", "two", "three"};

...そして で 4 番目の要素にアクセスしようとするとmyList[3]、そのエラーが発生します。

textBoxAllTotalContainer[0][2]存在しないか、またはtextBoxTotalContainer[0][2]. 写真のエラーからはわかりません。その行にブレークポイントを配置し、両方のオブジェクトをチェックします。

于 2013-08-18T00:54:53.410 に答える
0

停止条件が間違っているようです。
初期化するための次のコードがありますtextBoxAllTotalContainer

        //****TextBox for Total All****
        for (int y = 0; y <= 1; y++)
        {
            textBoxAllTotalContainer.Add(new List<TextBox>());
            textBoxAllTotalContainer[0].Add(new TextBox());
            textBoxAllTotalContainer[0][y].Size = new Size(175, 50);
            textBoxAllTotalContainer[0][y].Location = new Point(1150, 575);
            textBoxAllTotalContainer[0][y].TextChanged += new System.EventHandler(this.textBox_TextChanged);

            Controls.Add(textBoxAllTotalContainer[0][y]);
        }

ループは 2 回だけ繰り返されることに注意してください。したがってtextBoxAllTotalContainer[0][0]、 とtextBoxAllTotalContainer[0][1]が作成されます。

しかし、例外が指定するように、場所がリストの範囲外であるため、アクセスしようとするとtextBoxAllTotalContainer[0][2]例外が発生します。

于 2013-08-18T06:04:41.873 に答える