Excel长数字防止转换为科学计数法

网上的一个方法是,加单引号,但是不好看。

我的处理,是先加,再替换成带格式的。

        strTable = Formater.SimpleTable(dt, "aaa", "|f_Status|", "f_ID=ID;f_Time1=申报时间;f_Name=姓名;f_ZhuanYe1=专业;f_Sex=性别;f_Title=职称;f_Unit=单位;f_StatusText=申报进度;");

        strTable = strTable.Replace("<td>'", "<td style=\"vnd.ms-excel.numberformat:@\">");

 

 

参考:

http://www.cnblogs.com/kafeijiu/p/3761704.html?utm_source=tuicool

### C++ 中禁用科学计数法输出 为了在 C++ 中避免科学计数法输出数字,可以采用多种方式: #### 使用 `std::fixed` 控制流输出 通过设置流控制符 `std::fixed` 可以强制浮点数按照定点记数法显示而非指数形式。这通常用于标准库中的输入/输出流操作。 ```cpp #include <iostream> #include <iomanip> int main() { double number = 0.06666666666666; std::cout << "Default output: " << number << "\n"; std::cout.setf(std::ios_base::fixed, std::ios_base::floatfield); // 设置为固定格式 std::cout.precision(15); // 设定精度位数 std::cout << "Fixed notation: " << number << "\n"; return 0; } ``` 上述代码会先按默认模式打印数值,再应用固定的十进制定点表示并指定较高的精度[^1]。 #### 利用 `_gcvt_s` 函数进行转换 当需要将浮点数转成字符串而不希望其被自动转化为科学计数法时,可借助于 `_gcvt_s` 安全版本函数完成此任务。该方法允许精确度参数调整最终得到的字符度。 ```cpp #include <stdio.h> void convertDoubleToString(double value) { char buffer[50]; _gcvt_s(buffer, sizeof(buffer), value, 15); printf("Converted string: %s\n", buffer); } // 调用示例 convertDoubleToString(0.06666666666666); ``` 这段程序展示了如何利用 `_gcvt_s` 将双精度浮点数安全地转变为具有特定精度级别的字符串表达式[^3]。 #### CSV 文件保存时防止科学计数法 如果目标是在导出至CSV文件过程中阻止Excel或其他表格软件读取数据时将其解释为科学计数,则可以在每条记录之后附加一个不可见字符(如制表符),从而改变单元格的数据类型识别行为。 ```cpp #include <fstream> #include <string> void saveToCsv(const std::vector<double>& numbers) { std::ofstream file("output.csv"); for (auto num : numbers){ file << num << '\t' << "\n"; } } ``` 这里展示了一个简单例子,在向CSV写入每一行之前加上了制表符(`\t`)来规避可能发生的科学计数现象[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值