我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java后台怎么利用Pattern提取所需字符

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java后台怎么利用Pattern提取所需字符

这篇文章主要讲解了“java后台怎么利用Pattern提取所需字符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java后台怎么利用Pattern提取所需字符”吧!

    写在处理问题的前面

    由于项目功能迭代,导致原来的页面当中ID命名规则,与当前命名规则不同(ps:既然要用到原来的东西,为什么在设计的时候没有考虑到兼容的问题,无语),所以需要将原来的所有ID提取出来。

    遇到的问题,如何提取?

    查找了许多方法之后,感觉使用Pattern提取比较符合需求。于是开始尝试。

    1.首先进行简单测试

    String str = "{abc<icon>{def:</icon>}deftfh<icon>a</icon>}";Pattern p=Pattern.compile("<icon>\\{(\\w+)\\:</icon>");Matcher m=p2.matcher(str2);        while(m.find()){            System.out.println(m.group(1));            }

    好的没问题,提取正常。于是将所需提取的一部分字符串拿出来进行测试。

    2.项目内容测试

    String str = "\"EquipmentID\":\"SSC_FZ_DQ#MJ23JZ_FZ_CZ_CZGX#YL#SBBM\",";Pattern p=Pattern.compile("\"EquipmentID\":\"(\\w+)\",");Matcher m=p2.matcher(str2);        while(m.find()){            System.out.println(m.group(1));            }

    问题来了,没有提取到任何内容。那试试只提取EquipmentID当中的字符呢,测试没问题。问题就在正则匹配上了。(\\w+)只适用于截取文字部分,改为(.*),ok,可以正常截取SSC_FZ_DQ#MJ23JZ_FZ_CZ_CZGX#YL#SBBM这部分了。

    3.进行实操

    建立数据库连接。

    public class CopyOracle2MySQL1 {        private final String DEST_MYSQL_JDBC_URL = ;    private final String SOURCE_JDBC_URL = "";    private final String SOURCE_JDBC_USER = "";    private final String SOURCE_JDBC_PASSWORD = "";    public void startImport() throws Exception {        // 创建到两个数据库的连接        Class.forName("com.mysql.jdbc.Driver");        //Class.forName("oracle.jdbc.driver.OracleDriver");        Connection connDest = DriverManager.getConnection(DEST_MYSQL_JDBC_URL);        //Connection connSource = DriverManager.getConnection(SOURCE_JDBC_URL, SOURCE_JDBC_USER, SOURCE_JDBC_PASSWORD);        try {            // 人工输入各表名(需要保证顺序,以确保有外键的表在主表之后插入数据)            importTable(connDest, "APP_WGADDATA","qtsc_jk_scjkzttxx");        } finally {            // 自动关闭数据库资源            connDest.close();            //connSource.close();        }    }    private void importTable(Connection connDest, String oracleTableName,String mysqlTableName) throws Exception {        Statement stmt = null;        try {            stmt = connDest.createStatement();            String mysqlSql = "select ZTTNR from qtsc_jk_scjkzttxx qjs where qjs.ZTTID  = '0284fcbdcdbd4da3bdef78ed769515c6'";            String mysqlSql1 = "select ZTTNR from qtsc_jk_scjkzttxx";            ResultSet rs = stmt.executeQuery(mysqlSql1);            Map<String, String> sbbmMap = new HashMap();            while(rs.next()){                String zttnr = rs.getString(1);                //System.out.println(zttnr);                Pattern p = Pattern.compile("\"EquipmentID\":\"(.*)\",\"UnitName\"");                Matcher m=p.matcher(zttnr);                while(m.find()){                    System.out.println(m.group(1));                }                //System.out.println(sbbmMap);            }            // 先计算目标数据库的PreparedStatement的SQL语句z            ResultSetMetaData rsmd = rs.getMetaData();            rs.close();        }catch (Exception e){            e.printStackTrace();        }        finally {            if(stmt != null) {                stmt.close();            }        }    }    public static void main(String[] args) throws Exception {        CopyOracle2MySQL1 ins = new CopyOracle2MySQL1();        ins.startImport();    }

    测试结果发现,在所有符合规则的前期下进行提取,发现,自动匹配到了最后一个",“UnitName”,很显然又是规则的问题,于是将(.)改为(.?)问题解决。

    附:JAVA Pattern正则获取大括号中内容

    利用正则表达式获取字符串中想要的值:

    获取符串场景: 你好呀(嘻嘻)

    我需要获取“嘻嘻” 该如何获取呢?

    通过正则表达式获取:

            String str = "你好呀(嘻嘻)";        Pattern p = Pattern.compile("\\(([^\\)]+)");        Matcher matcher = p.matcher(str);        if (matcher.find() && matcher.groupCount() >= 1){            System.out.println(matcher.group(1));        }

    通过字符截取获取:

            String str = "你好呀(嘻嘻)";        String xixi = str.substring(str.indexOf("(") + 1, str.indexOf(")"));        System.out.println(xixi);

    感谢各位的阅读,以上就是“java后台怎么利用Pattern提取所需字符”的内容了,经过本文的学习后,相信大家对java后台怎么利用Pattern提取所需字符这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    java后台怎么利用Pattern提取所需字符

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    java后台怎么利用Pattern提取所需字符

    这篇文章主要讲解了“java后台怎么利用Pattern提取所需字符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java后台怎么利用Pattern提取所需字符”吧!写在处理问题的前面由于项目
    2023-06-26

    利用java怎么在后台将base64字符串保存为图片

    本篇文章为大家展示了利用java怎么在后台将base64字符串保存为图片,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。具体方法如下:import java.io.FileOutputStream;
    2023-05-31

    怎么在java中利用Scanner获取字符串

    今天就跟大家聊聊有关怎么在java中利用Scanner获取字符串,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合于各种
    2023-06-14

    java怎么用正则表达式匹配与提取字符串

    本文小编为大家详细介绍“java怎么用正则表达式匹配与提取字符串”,内容详细,步骤清晰,细节处理妥当,希望这篇“java怎么用正则表达式匹配与提取字符串”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。首先给出一个匹
    2023-07-02

    怎么使用Java正则表达式匹配字符串并提取中间值

    今天小编给大家分享一下怎么使用Java正则表达式匹配字符串并提取中间值的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前言有时
    2023-07-02

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录