java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0

来源:http://www.cnblogs.com/zuidongfeng/archive/2016/06/13/5582269.html
-Advertisement-
Play Games

使用repalceAll 方法出現java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0異常 代碼如下: 以junit測試方式運行後報瞭如下錯誤: java.util.regex.Pattern ...


使用repalceAll 方法出現java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0異常

 

代碼如下:

1     @Test
2     public void testReplaceAll(){
3         String sql = "select * from per_handle where id not in('3ce7405509414105a65e7456987e7393')";        
4          String countSql = sql.replaceAll("*", " count(*) ");
5 
6         System.out.println(countSql);
7     }    

以junit測試方式運行後報瞭如下錯誤:

  java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0

 

出現這個錯誤與repalceAll方法有關,查閱java API文檔可以看到 replaceAll方法結構如下:

String java.lang.String.replaceAll(String regex, String replacement) 

使用給定的 replacement 替換此字元串所有匹配給定的正則表達式的子字元串。

第一個參數是一個正則表達式,第二個參數為替換後的字元串。

由於"*"在正則表達式中有特殊意義,導致報錯。

 

嘗試了兩種解決方法:

1、對"*"進行轉義處理,使之成為一個普通字元

1 @Test
2 public void testReplaceAll(){
3     String sql = "select * from per_handle where id not in('3ce7405509414105a65e7456987e7393')";        
4     String countSql = sql.replaceAll("\\*", " count(*) ");
5     System.out.println(countSql);
6 }

2、使用replace方法代替replaceAll方法

1 @Test
2 public void testReplaceAll(){
3     String sql = "select * from per_handle where id not in('3ce7405509414105a65e7456987e7393')";        
4     String countSql = sql.replace("*", " count(*) ");
5     System.out.println(countSql);
6 }

這種方法能夠成功的原因是:

String java.lang.String.replace(CharSequence target, CharSequence replacement)

replace方法的第一參數為字元或字元串,所以預設會將"*"當成普通字元串。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 建立Python的開發環境 2.第一個Python程式,還是從Hello World開始 3. debug一下python程式 <1>. 建立Python的開發環境; 這裡使用的Python的開發環境是eclipse + pydev插件來配置python的開發環境,如果想要在命令行下使用pyt ...
  • 編寫良好的代碼是一種藝術。如果一個程式員遵循一些良好的編程習慣,那麼他就可以成為一個優秀的程式員。實際上,相對於你寫代碼的時間,你很可能會花更多的時間在代碼維護上;更不用說整個應用程式的維護。建立良好的編碼習慣,能夠提高像模塊化這樣的設計因素,你的代碼也將更容易理解,因此,維護起來更容易、成本更低。 ...
  • 很久之前參加過一次面試,記得當時面試官問過我一個很基礎的代碼題:實現string類的四大基本函數! 一個C++類一般至少有四大函數,即構造函數、拷貝構造函數、析構函數和賦值函數,一般系統都會預設。但是往往系統預設的並不是我們所期望的,為此我們就有必要自己創造他們。在創造之前必須瞭解他們的作用和意義, ...
  • 引言 為什麼需要鎖(併發控制)? 在多用戶環境中,在同一時間可能會有多個用戶更新相同的記錄,這會產生衝突。這就是著名的併發性問題。 典型的衝突有: 丟失更新:一個事務的更新覆蓋了其它事務的更新結果,就是所謂的更新丟失。例如:用戶A把值從6改為2,用戶B把值從2改為6,則用戶A丟失了他的更新。 臟讀: ...
  • 每次用到mysql_connect連接資料庫的時候都會提示: 作為一個高要求高完美的男人,實在受不了這提示。躲著他也不行——解決他心裡的小石頭才能碎掉 那麼就先學習下使用Mysqli操作資料庫: 1. 與Mysql資料庫交互時,首先要建立連接,最後要斷開連接,這包括與伺服器連接並選擇一個資料庫,以及 ...
  • 好久沒翻譯simple java了,睡前來一發。譯文鏈接:http://www.programcreek.com/2014/01/java-serialization/ 什麼是對象序列化 在Java中,對象序列化指的是將對象用位元組序列的形式表示,這些位元組序列包含了對象的數據和信息,一個序列化後的對象 ...
  • 如果你伺服器環境允許yum,安裝MySQL-python模塊就很簡單了。 如果直接安裝不行,先 安裝MySQL-devel後正常運行 yum install mysql-devel yum install MySQL-python -y 1 yum install MySQL-python -y 當 ...
  • 這裡首先有一個問題要考慮的是,這類方法是否要被測試? 理論上,這類方法都會被其它public類型的方法調用,只要對那些public的方法做充分的測試,就可以保證這些方法的可靠性,就沒有必要再測了。好像是有道理的。 我們先看看好的單元測試的原則:(ATRIP) 自動化(Automatic) 徹底(Th ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...