如果所示,需要把字符串中存在的英文双引号 " " 转换成中文双引号 “ ”
2条回答 默认 最新
关注 如果不要求成对的话,直接用replace就好了,英文双引号是不存在左右的,但中文双引号有左右之分
replace(字段名,'"','“ ')
如果要求左右成对,可能就有点麻烦,因为不确定这个字符串中是否存在中英文双引号混用,以及是否存在多对双引号的情况,不能简单的按单数位置的双引号改成左双引号,双数位置的双引号改成右双引号,因此在不清楚数据到底有哪些可能性的情况下,这个可能都得靠机器学习来识别语义了。
但如果只有一对双引号,结合用substr结合instr,或者用正则替换都可以处理,以下sql为示意select substr(a, 1, instr(a, '"', 1, 1) - 1) || '左' || substr(a, instr(a, '"', 1, 1) + 1, instr(a, '"', 1, 2) - instr(a, '"', 1, 1)-1) || '右' || substr(a, instr(a, '"', 1, 2) + 1) from (select 'sdasf"214fgfv"wfff' a from dual);
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
- ¥50 如何openEuler 22.03上安装配置drbd
- ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
- ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
- ¥15 Windows11, backspace, enter, space键失灵