25

I have a problem in code in C#:

I don't know how to implement logic - iterating through Hashtable having values of different data types, the schema I want is below:

if the value in variable is String type
{
 do action1;
}
else 
{
  do action2;
}

There is a hashtable containing data of Types - String and Int (combined):

public string SQLCondGenerator {

        get
        {

            Hashtable conditions = new Hashtable();

            //data having String data type
            conditions.Add("miap", ViewState["miap_txt"]);
            conditions.Add("pocode", ViewState["po_txt "]);
            conditions.Add("materialdescription", ViewState["mat_desc_txt"]);
            conditions.Add("suppliername", ViewState["supplier_txt"]);
            conditions.Add("manufacturername", ViewState["manufacturer_txt"]);

            //data having Int32 data type
            conditions.Add("spareparts", ViewState["sp_id"]); 
            conditions.Add("firstfills", ViewState["ff_id"]);
            conditions.Add("specialtools", ViewState["st_id"]);
            conditions.Add("ps_deleted", ViewState["ps_del_id"]);
            conditions.Add("po_manuallyinserted", ViewState["man_ins_id"]);

            String SQLCondString = "";
            String SQLCondStringConverted = "";


            string s = string.Empty;
            foreach (string name in conditions.Keys) 
            {
                if (conditions[name] != null)
                {
                    SQLCondString += name+ "=" +conditions[name]+ " and ";
                    Response.Write(conditions[name].GetType());

                    bool valtype = conditions[name].GetType().IsValueType;
                    if (valtype == string)
                    {
                      SQLCondString.Substring(0, SQLCondString.Length - 4);
                      SQLCondString += name + " and like '%" + conditions[name] + "%' and ";
                    }
                }
            }

        //Response.Write("********************");
         SQLCondStringConverted = SQLCondString.Substring(0, SQLCondString.Length - 4);
         return SQLCondStringConverted;
        }   
    }

May be I am wrong in coding, please advise!

Thanks!

4

4 回答 4

58
if(conditions[name] is string)
{
}
else
{
}
于 2012-12-19T16:01:56.747 回答
8

Hmm, I'm not sure why you are calling IsValueType, but this should be sufficient:

if (conditions[name] is string) 
{
    ///  
}
于 2012-12-19T16:02:10.857 回答
2

方法 - 1

Int32 Val = 0;
if (Int32.TryParse("Your Value", out Val))
{
    //Your Logic for int
}
else
{
    //Your Logic for String
}

方法 - 2(使用后期绑定)

Int32 Val = 0;
dynamic conditions = new Hashtable();
conditions.Add("miap", ViewState["miap_txt"]);
conditions.Add("pocode", ViewState["po_txt "]);
foreach (string name in conditions.Keys)
{
    if (Int32.TryParse(conditions[name].ToString(), out Val))
    {
        //Your Logic for int
    }
    else
    {
        //Your Logic for String
    }
}
于 2012-12-19T16:28:18.273 回答
0

我遇到了同样的问题,但我使用的是文本框,需要验证输入是字母、- 还是 .

我在我的文本框上生成了一个按键事件,并插入了以下方法来检查每个按键并在它不是有效字符时给出提示:

public static class Validator
{
public static bool IsNameString(TextBox tb, string name, KeyPressEventArgs e)
    {
        bool valid = true;

        /*  e.KeyChar contains the character that was pressed
         e.Handled is a boolean that indicates that handling is done            
        if a bad character is entered, set e.Handled to true
        */
        if (!char.IsLetter(e.KeyChar) && e.KeyChar != ' ' && e.KeyChar != '-' &&
          e.KeyChar != '.' && e.KeyChar != (char)Keys.Back)
        {
            e.Handled = true;
            valid = false;
            MessageBox.Show(name+ " can only accept letters, space, - and .");
            tb.Focus();

        }
        return valid;
    }
}

用法:

 private void txtCustomerName_KeyPress(object sender, KeyPressEventArgs e)
    {            
       Validator.IsNameString(txtCustomerName, "Customer Name", e);

    }
于 2019-12-23T18:23:16.667 回答