回复 3楼jplzj的帖子
在我这边测试正常,主要是以下方法启作用:
- private void fpSpread1_EditModeOff(object sender, EventArgs e)
- {
- FarPoint.Win.Spread.CellType.RegularExpressionCellType editor = this.fpSpread1.Sheets[0].GetEditor(0, 0) as FarPoint.Win.Spread.CellType.RegularExpressionCellType;
- string text = ToDBC(this.fpSpread1.EditingControl.Text);
- this.fpSpread1.Sheets[0].ActiveCell.Text = text;
- }
- // /全角空格为12288,半角空格为32
- // /其他字符半角(33-126)与全角(65281-65374)的对应关系是:均相差65248
- public static String ToDBC(String input)
- {
- char[] c = input.ToCharArray();
- for (int i = 0; i < c.Length; i++)
- {
- if (c[i] == 12288)
- {
- c[i] = (char)32;
- continue;
- }
- if (c[i] > 65280 && c[i] < 65375)
- c[i] = (char)(c[i] - 65248);
- }
- return new String(c);
- }
复制代码
为什么要把 全角转换为半角?Spread 7.0 可以自动切换全角半角输入:
- this.fpSpread1.ImeMode = System.Windows.Forms.ImeMode.OnHalf;
复制代码 |