1 把一个模型类集合,中的某个字段,转换成List<T>类型:
var tradeIDlist=staList.Select(p => p.TradeID).ToList();
2 把一个List<long> 类型,转换成以逗号隔开拼接的字符串
string.Join(',', tradeIDlist);
4 正则表达式断言用法,这是我写抽奖程序时用到的。 20160221晚
原数据: 2:50/1000,8:20/1000,28:2/1000,88:1/1000,288:0/1000,0:927/1000
需要得到所有:与/符号中间的数据。
直接这样写正则 :\d+/ 出来的结果会是 :50/ :20/ ......
但我们实际需要的是:/符号不出来,只需要中间的数据。这就需要用到断言。
直接上正确的正则 (?<=:)\d+(?=/)
解释: ?<=是零宽先行断言, (?<=:)意为前面不包括冒号。?=表示零宽后发断言,(?=/)表示后面不包括/符号。
5 winform程序,在使用多线程时,对主线程上的控件赋值时,以前都是自己封装了一个方法,用反射,自认为很好了。因为它可以自动识别类型。现在竟然发现了更好的办法,一句代码就搞定了:
var tradeIDlist=staList.Select(p => p.TradeID).ToList();
2 把一个List<long> 类型,转换成以逗号隔开拼接的字符串
string.Join(',', tradeIDlist);
3 /// 返回一组不重复随机数生成方法-(完美,100%不重复)。
/// min 最小数,max 最大数,num 输出个数
/// 吴官迪 20160220
/// </summary>
/// <param name="min"></param>
/// <param name="max"></param>
/// <param name="num"></param>
/// <returns></returns>
public static List<int> GetNoRepeatRandom(int min, int max, int num)
{
//把数据先装进数组。
int[] yu = new int[max-min];
for (int i = 0; i < max - min; i++)
{
yu[i] =min+i;
}
//将要返回的随机数的数量。
List<int> list = new List<int>();
//安全性判断
if (num > yu.Length)
{
return list;
}
//这个一定要注意,不能放在循环内,会造成出来的随机数像排过序一样
Random ran = new Random();
for (int i = 0; i < num; i++)
{
//从数组中生成随机数
int intRan=ran.Next(yu.Length);
list.Add(yu[intRan]);
//把生成出来的随机数,从数组中去除。再次从数组中进行随机,就永远不会出现重复。
yu = yu.Where(p => p != yu[intRan]).ToArray();
}
return list;
}
4 正则表达式断言用法,这是我写抽奖程序时用到的。 20160221晚
原数据: 2:50/1000,8:20/1000,28:2/1000,88:1/1000,288:0/1000,0:927/1000
需要得到所有:与/符号中间的数据。
直接这样写正则 :\d+/ 出来的结果会是 :50/ :20/ ......
但我们实际需要的是:/符号不出来,只需要中间的数据。这就需要用到断言。
直接上正确的正则 (?<=:)\d+(?=/)
解释: ?<=是零宽先行断言, (?<=:)意为前面不包括冒号。?=表示零宽后发断言,(?=/)表示后面不包括/符号。
5 winform程序,在使用多线程时,对主线程上的控件赋值时,以前都是自己封装了一个方法,用反射,自认为很好了。因为它可以自动识别类型。现在竟然发现了更好的办法,一句代码就搞定了:
this.Invoke(new Action(() => { comboBox1.Items.Add("上衣"); }));
6 datatable的linq使用
row["在单数量"] = NewOrder.AsEnumerable().Where(d => d.Field<string>("款号") == row["款号"]).Sum(p => p.Field<int>("数量"));
List<string> list= NewOrder.AsEnumerable().Select(d => d.Field<string>("款号"));