存档

‘软件开发’ 分类的存档

C#实现Excel列名与列索引间的转换

2011年3月26日 Tal Rasha 1,069 views 没有评论

写代码使用到的Excel列名与列索引间的转换,贴出来分享
其实就是十进制和二十六进制间的转换

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
        /// <summary>
        /// 用于excel表格中列号字母转成列索引,从1对应A开始
        /// </summary>
        /// <param name="column">列号</param>
        /// <returns>列索引</returns>
        private int ColumnToIndex(string column)
        {
            if (!Regex.IsMatch(column.ToUpper(), @"[A-Z]+"))
            {
                throw new Exception("Invalid parameter");
            }
            int index = 0;
            char[] chars = column.ToUpper().ToCharArray();
            for (int i = 0; i < chars.Length; i++)
            {
                index += ((int)chars[i] - (int)'A' + 1) * (int)Math.Pow(26, chars.Length - i - 1);
            }
            return index;
        }
 
        /// <summary>
        /// 用于将excel表格中列索引转成列号字母,从A对应1开始
        /// </summary>
        /// <param name="index">列索引</param>
        /// <returns>列号</returns>
        private string IndexToColumn(int index)
        {
            if (index <= 0)
            {
                throw new Exception("Invalid parameter");
            }
            index--;
            string column = string.Empty;
            do
            {
                if (column.Length > 0)
                {
                    index--;
                }
                column = ((char)(index % 26 + (int)'A')).ToString() + column;
                index = (int)((index - index % 26) / 26);
            } while (index > 0);
            return column;
        }
分类: 软件开发 标签: ,

人民币小写转换成大写

2011年3月14日 Tal Rasha 644 views 没有评论
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
/**
 * 人民币小写转换成大写
 * @param s 人民币小写(比如:12043000.01)
 * @return 人民币大写(比如:壹仟贰佰零肆万叁仟元零壹分)
 */
public static String getNumberToRMB(String s) {
    if (s == null || s.trim().length() == 0) {
        return s;
    }
 
    StringBuilder rmbChinese = new StringBuilder();
    // 小数点位置
    int xsdwz = s.indexOf(".");
    // 整数部分
    String integral = "";
    // 角分部分
    String decimal = "";
    String[] wy = {};
    int xh = 0;
    String prefix = ""; // 整数部分转化的结果
    String suffix = ""; // 小数部分转化的结果
 
    if (xsdwz >= 0) {
        integral = s.substring(0, xsdwz);
        if (!integral.equals("")) {
            if (Double.parseDouble(integral) == 0) {
                integral = "";
            }
        }
        decimal = s.substring(xsdwz + 1, s.length());
        //for(int i=0;i<new)
        if (decimal.length() < 2) {
            decimal += "0";
        }
    } else {
        integral = s;
        decimal = "";
        //new2="00";
    }
    if (integral.length() > 0) {
        if (integral.substring(0, 1).equals("-") || integral.substring(0, 1).equals("+")) {
            if (integral.substring(0, 1).equals("-")) {
                rmbChinese.append("负");
            }
            // 去掉前面的正、负符号
            integral = integral.substring(1, integral.length());
        }
    }
 
    if (integral.length() % 4 == 0) {
        xh = integral.length() / 4;
        //wy = new String[new1.length() / 4];
    } else {
        xh = integral.length() / 4 + 1;
        //wy = new String[new1.length() / 4 + 1];
    }
    wy = new String[xh];
    for (int i = 0; i < xh; i++) {
        if ((i + 1) * 4 <= integral.length()) {
            wy[i] = integral.substring(integral.length() - (i + 1) * 4, integral.length() - i * 4);
        } else {
            wy[i] = integral.substring(0, integral.length() % 4);
        }
        //System.out.println(wy);
    }
 
    if (integral.length() > 0 && Integer.parseInt(decimal) > 9) {
        rmbChinese.append(getDxZs(integral, 1, wy));
        rmbChinese.append(getDxJf(decimal));
    } else if (integral.length() > 0 && (Integer.parseInt(decimal) > 0 && Integer.parseInt(decimal) <= 9)) {
        rmbChinese.append(getDxZs(integral, 3, wy));
        rmbChinese.append(getDxJf(decimal));
    } else if (integral.length() > 0 && Integer.parseInt(decimal) == 0) {
        rmbChinese.append(getDxZs(integral, 2, wy));
    } else if (integral.length() == 0 && Integer.parseInt(decimal) > 0) {
        rmbChinese.append(getDxJf(decimal));
    }
    return rmbChinese.toString();
}
 
/**
 * 获得大写整数部分
 * @param s
 * @param i1
 * @param wy
 * @return
 */
private static String getDxZs(String s, int i1, String[] wy) {
    StringBuilder dxzs = new StringBuilder();
    for (int i = 0; i < s.length(); i++) {
        if (Integer.parseInt(s.substring(i, 1 + i)) > 0) {
            if (i > 0 && i < s.length() - 1) {
                if (Integer.parseInt(s.substring(i - 1, i)) == 0) {
                    dxzs.append("零");
                    dxzs.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
                    dxzs.append(getWeiShu(s.length() - i));
                } else {
                    dxzs.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
                    dxzs.append(getWeiShu(s.length() - i));
                }
            } else if (i == s.length() - 1) {// && i!=0) {
                if (i != 0 && Integer.parseInt(s.substring(i - 1, i)) == 0) {
                    dxzs.append("零");
                }
                if (i1 == 1) {
                    dxzs.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
                    dxzs.append(getWeiShu(s.length() - i));
                } else if (i1 == 2) {
                    dxzs.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
                    dxzs.append(getWeiShu(s.length() - i));
                    dxzs.append("整");
                } else if (i1 == 3) {
                    dxzs.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
                    dxzs.append(getWeiShu(s.length() - i));
                    dxzs.append("零");
                }
            } else if (i == 0) { //&& i != s.length() - 1) {
                dxzs.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
                dxzs.append(getWeiShu(s.length() - i));
            }
        } else if (Integer.parseInt(s.substring(i, i + 1)) == 0) {
            if (i > 0 && i < s.length() - 1) {
                if (s.length() - i == 9) {
                    if (Integer.parseInt(wy[2]) != 0) {
                        dxzs.append("亿");
                    }
                } else if (s.length() - i == 5) {
                    if (Integer.parseInt(wy[1]) != 0) {
                        dxzs.append("万");
                    }
                }
            } else if (i > 0 && i == s.length() - 1) {
                if (i1 == 1) {
                    dxzs.append("元零");
                } else if (i1 == 2) {
                    dxzs.append("元整");
                } else if (i1 == 3) {
                    dxzs.append("元零");
                }
            }
        }
    }
    return dxzs.toString();
}
 
/**
 * 获得大写角分部分
 * @param s
 * @return
 */
private static String getDxJf(String s) {
    StringBuilder dxjf = new StringBuilder();
 
    for (int i = 0; i < s.length(); i++) {
        if (Integer.parseInt(s.substring(i, i + 1)) != 0) {
            dxjf.append(getHanZi(Integer.parseInt(s.substring(i, i + 1))));
            dxjf.append(getJiaFen(i + 1));
        } else if (Integer.parseInt(s.substring(i, i + 1)) == 0 && i == 1) {
            dxjf.append("整");
        }
    }
    return dxjf.toString();
}
 
/**
 * 获得角、分
 * @param s
 * @return
 */
private static String getJiaFen(int s) {
    String hz = "";
    if (s == 1) {
        hz = "角";
    } else if (s == 2) {
        hz = "分";
    }
    return hz;
}
 
/**
 * 获得数字的大写汉字
 * @param s 0~9的整数
 * @return 零~玖的汉字
 */
private static String getHanZi(int s) {
    String[] hzDigit = {
        "零",
        "壹",
        "贰",
        "叁",
        "肆",
        "伍",
        "陆",
        "柒",
        "捌",
        "玖"
    };
    return hzDigit[s];
}
 
/**
 * 获得位数
 * @param s
 * @return
 */
private static String getWeiShu(int s) {
    String hz = "";
    if (s == 1) {
        hz = "元";
    } else if (s == 2) {
        hz = "拾";
    } else if (s == 3) {
        hz = "佰";
    } else if (s == 4) {
        hz = "仟";
    } else if (s == 5) {
        hz = "万";
    } else if (s == 6) {
        hz = "拾";
    } else if (s == 7) {
        hz = "佰";
    } else if (s == 8) {
        hz = "仟";
    } else if (s == 9) {
        hz = "亿";
    } else if (s == 10) {
        hz = "拾";
    } else if (s == 11) {
        hz = "佰";
    } else if (s == 12) {
        hz = "仟";
    }
    return hz;
}

SQL SERVER 批量删除默认值

2010年11月6日 Tal Rasha 891 views 没有评论
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
--表名
declare @tablename sysname;
--默认值约束名
declare @defaultname varchar(100);
--定义游标
declare DFCursor CURSOR for
select so.name as 表名,object_name(sm.id) as 约束
from dbo.sysobjects so 
    JOIN dbo.syscolumns sc 
on SO.id = SC.id
    JOIN dbo.syscomments sm 
on SC.cdefault = sm.id
where SO.xtype = 'u'
--打开游标
open DFCursor
--从游标取记录
fetch next from DFCursor into @tablename, @defaultname
--当有记录
while @@fetch_status=0
begin
--先去掉该缺省值
exec('alter table '+@tablename+' drop constraint '+@defaultname);
--取下一条记录
fetch next from DFCursor into @tablename, @defaultname
end
--关闭游标
close DFCursor
--删除游标引用
deallocate DFCursor
 
--下面是查询语句的两种方案
 
--1
--select so.name as 表名,sc.name as 字段名,sm.text as 默认值,object_name(sm.id) as 约束
--from dbo.sysobjects so 
--    JOIN dbo.syscolumns sc 
--on SO.id = SC.id
--    JOIN dbo.syscomments sm 
--on SC.cdefault = sm.id
--where SO.xtype = 'u'
 
--2
--select t3.name as 表名,t1.name as 字段名,t2.text as 默认值,t4.name as 约束
--from syscolumns t1,syscomments t2,sysobjects t3,sysobjects t4
--where t1.cdefault=t2.id and t3.xtype='u' and t3.id=t1.id and t4.xtype='d' and t4.id=t2.id
分类: 软件开发 标签: ,

ASP.NET 获取当前时间

2010年10月16日 Tal Rasha 1,212 views 3 条评论

好久没更新了,难得有心情回来看看,之后会慢慢更新吧,但愿。今天就先更新一篇。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
//获取日期+时间
DateTime.Now.ToString();            // 2008-9-4 20:02:10
DateTime.Now.ToLocalTime().ToString();        // 2008-9-4 20:12:12
 
//获取日期
DateTime.Now.ToLongDateString().ToString();    // 2008年9月4日
DateTime.Now.ToShortDateString().ToString();    // 2008-9-4
DateTime.Now.ToString("yyyy-MM-dd");        // 2008-09-04
DateTime.Now.Date.ToString();            // 2008-9-4 0:00:00
//获取时间
DateTime.Now.ToLongTimeString().ToString();    // 20:16:16
DateTime.Now.ToShortTimeString().ToString();    // 20:16
DateTime.Now.ToString("hh:mm:ss");         // 08:05:57
DateTime.Now.TimeOfDay.ToString();         // 20:33:50.7187500
 
//其他
DateTime.ToFileTime().ToString();        // 128650040212500000
DateTime.Now.ToFileTimeUtc().ToString();    // 128650040772968750
DateTime.Now.ToOADate().ToString();        // 39695.8461709606
DateTime.Now.ToUniversalTime().ToString();    // 2008-9-4 12:19:14
 
DateTime.Now.Year.ToString();          获取年份    // 2008
DateTime.Now.Month.ToString();      获取月份    // 9
DateTime.Now.DayOfWeek.ToString();  获取星期    // Thursday
DateTime.Now.DayOfYear.ToString();  获取第几天    // 248
DateTime.Now.Hour.ToString();          获取小时    // 20
DateTime.Now.Minute.ToString();     获取分钟    // 31
DateTime.Now.Second.ToString();     获取秒数    // 45
 
//n为一个数,可以数整数,也可以事小数
dt.AddYears(n).ToString();    //时间加n年
dt.AddDays(n).ToString();    //加n天
dt.AddHours(n).ToString();    //加n小时
dt.AddMonths(n).ToString();    //加n个月
dt.AddSeconds(n).ToString();    //加n秒
dt.AddMinutes(n).ToString();    //加n分
分类: 软件开发 标签: ,

Java基础面试题

2010年7月20日 Tal Rasha 1,027 views 2 条评论

1、作用域public,private,protected,以及不写时的区别?
答:区别如下:

作用域 当前类 同一package 子类 其他package
public
protect ×
friendly × ×
private × × ×

不写时默认为friendly

2、char型变量中能不能存贮一个中文汉字?为什么?
答:是能够定义成为一个中文的,因为java中以unicode编码,一个char占16个字节,所以放一个中文字符是没问题的。

3、Anonymous Inner Class (匿名内部类) 是否可以extends(继承)其它类,是否可以implements(实现)interface(接口)?
答:匿名的内部类是没有名字的内部类,不能extends(继承) 其它类,但一个内部类可以作为一个接口,由另一个内部类实现。
(全文 …)

分类: 软件开发 标签: , ,