按照字节截取字符串
C#中substring默认是将汉字当一个字节来截取的,但是我需要把汉字按照2个字节来算。
如果String str = "买价1,467,cs,你好,hello"
我只想要前九个字节
private static Encoding _encoding = System.Text.Encoding.GetEncoding( "GB2312" ); private void RibbonForm1_Load( object sender, EventArgs e) { String str = "买价1,467cs,你好,hello" ; labelControl1.Text = str.Substring(0, 9); labelControl2.Text = SubstringByte(str, 0, 9); labelControl3.Text = cutSubstring(str, 8); labelControl4.Text = SubstringByte(str, 0, 3); labelControl5.Text = cutSubstring(str, 3); } //第一种方法 private string SubstringByte( string text, int startIndex, int length) { byte [] bytes = _encoding.GetBytes(text); return _encoding.GetString(bytes, startIndex, length); } //第二种方法 private string cutSubstring( string s, int length) { byte [] bytes = System.Text.Encoding.Unicode.GetBytes(s); int n = 0; // 表示当前的字节数 int i = 0; // 要截取的字节数 for (; i < bytes.GetLength(0) && n < length; i++) { // 偶数位置,如0、2、4等,为UCS2编码中两个字节的第一个字节 if (i % 2 == 0) { n++; // 在UCS2第一个字节时n加1 } else { // 当UCS2编码的第二个字节大于0时,该UCS2字符为汉字,一个汉字算两个字节 if (bytes[i] > 0) { n++; } } } // 如果i为奇数时,处理成偶数 if (i % 2 == 1) { // 该UCS2字符是汉字时,去掉这个截一半的汉字 if (bytes[i] > 0) i = i - 1; // 该UCS2字符是字母或数字,则保留该字符 else i = i + 1; } return System.Text.Encoding.Unicode.GetString(bytes, 0, i); }<br> |
以上是结果展示。
一天积累一点。。。加油!
天再高,踮起脚尖就能更接近阳光
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?