Java의 문자열에서 JSON 어레이 값 추출에 대한 실용 가이드
비표준 소스에서 얻은 로그 출력 또는 문자열 데이터를 처리 할 때는 종종 JSON 어레이의 모든 값과 같은 특정 JSON 구조를 추출해야합니다. 정규 표현은 텍스트 일치에서 강력하지만 복잡한 JSON 구조에 대한 유지 보수 및 견고성에 불충분합니다. 이 기사는 성숙한 JSON 구문 분석 라이브러리를 사용하고 특정 시나리오에서 수동 추출을위한 정규 표현식을 사용하는 두 가지 주요 방법을 소개합니다.
1. JSON 구문 분석 라이브러리를 사용하는 것이 좋습니다
JSON 데이터를 처리 할 때 가장 권장되고 강력한 방법은 Jackson, GSON 등과 같은 특수 JSON 구문 분석 라이브러리를 사용하는 것입니다. 이러한 라이브러리는 중첩 구조, 탈출 된 문자 등을 포함한 JSON의 복잡성을 처리하고 유형-안전 구문 분석 방법을 제공하고 개발 작업을 크게 단순화하고 코드 유지 관리를 개선 할 수 있습니다.
1.1 구조화 된 데이터 분석에 POJO 사용
JSON 데이터의 구조가 미리 알려지고 비교적 고정 된 경우, JSON 구조는 Java 객체 (Plain Old Java Object, Pojo)를 정의하여 매핑 할 수 있습니다. 이것은 가장 일반적이고 권장되는 구문 분석 방법입니다.
샘플 JSON 데이터 :
{ "가치": [ "ABC123", "def456", "XYZ789" ]] }
해당 POJO 정의 :
Java.util.list 가져 오기; 공개 클래스 mypojo { 개인 목록 <string> 값; // 생성자 public mypojo () {} // getter 공개 목록 <string> getValues () { 반환 값; } // 세터 public void setValues (list <string> value) { this.values = 값; } @보수 공개 문자열 tostring () { "mypojo {"반환 "value ="값 '}'; } }</string></string></string>
구문 분석에는 Jackson Library를 사용하십시오.
com.fasterxml.jackson.databind.objectmapper 가져 오기; import com.fasterxml.jackson.databind.json.jsonmapper; Java.util.list 가져 오기; 공개 클래스 JSONPOJOPARSER { public static void main (string [] args)은 예외 { String jsonstal = "{\"value \ ": [\"abc123 \ ", \"def456 \ ", \"xyz789 \ "]}"; ObjectMapper Mapper = new JsonMapper (); mypojo pojo = mapper.readValue (jsonst, mypojo.class); System.out.println ( "추출 값 :"pojo.getValues ()); // 출력 : 추출 값 : [ABC123, DEF456, XYZ789] } }
Pojo 방법을 통해 JSON 스트링은 Java 객체로 직접 사막화됩니다. 개발자는 일반적인 Java 개체를 운영하는 것과 같은 데이터를 얻을 수 있으며 명확한 코드와 오류가 발생하지 않습니다.
1.2 동적 데이터 구문 분석에 JSONNODE를 사용하십시오
JSON 구조가 고정되지 않았거나 데이터의 일부만 추출하고 전체 JSON의 POJO를 정의하고 싶지 않은 경우 JSON을 트리 (JSONNODE)로 구문 분석하여 노드 경로를 통해 액세스 할 수 있습니다.
JSONNODE 구문 분석에는 Jackson Library를 사용하십시오.
com.fasterxml.jackson.core.type.typereference import; com.fasterxml.jackson.databind.jsonnode import; com.fasterxml.jackson.databind.objectmapper 가져 오기; import com.fasterxml.jackson.databind.json.jsonmapper; Java.util.list 가져 오기; 공개 클래스 JSONNODEPARSER { public static void main (string [] args)은 예외 { String jsonstal = "{\"value \ ": [\"abc123 \ ", \"def456 \ ", \"xyz789 \ "]}"; ObjectMapper Mapper = new JsonMapper (); // JSON 문자열을 JSONNODE 트리에 parses jsonnode rootnode = mappper.readtree (jsonst); // "값"이라는 노드를 가져옵니다. // 값 노드의 내용을 <string> 목록으로 삼으십시오. list <string> values = mappper.readerfor (new typereference <list>> () {}). readValue (valueNode); System.out.println ( "추출 값 :"); values.foreach (System.out :: println); /* * 출력 : * ABC123 * def456 * XYZ789 */ } }</list></string></string>
이 접근법은 더 큰 유연성을 제공하며 구조물이 가변적이거나 부분 데이터 만 필요한 시나리오를 처리하는 데 적합합니다.
2. 정규 표현을 통한 수동 추출
엄격한 런타임 환경이있는 경우, 타사 라이브러리를 도입 할 수 없거나 매우 간단하고 매우 일관된 형식의 문자열에서 특정 조각을 추출 해야하는 것과 같은 드문 경우에 정규 표현식을 고려할 수 있습니다. 그러나 정규 표현식은 JSON의 복잡성에 대한 지원이 부족한 JSON (예 : 중첩, 탈출 된 문자, 다른 데이터 유형)에 대한 지원이 부족한 JSON을 처리하기위한 이상적인 도구가 아니라는 점에 유의해야합니다.
2.1 적용 가능한 시나리오 및 제한
- 적용 가능한 시나리오 : 문자열에 포함 된 JSON 조각은 고정 된 구조로 매우 간단하며 가장 바깥 쪽 배열의 값만 추출해야합니다. 예를 들어, { "value": [ "a", "b", "c"} 형식으로 로그에서 조각을 추출합니다.
- 제한 사항 : 중첩 JSON, JSON 객체, 다른 데이터 유형 (숫자, 부울 값 등), 특수 문자가 포함 된 문자열 또는 이스케이프 문자를 처리 할 수 없습니다. 정규 표현은 약간 복잡하거나 덜 엄격한 JSON의 경우 실패하기 쉽습니다.
2.2 정규 표현 전략 향상
정규 표현식 \ "value \"\ s*: \ s*\ [(\ s*\ "(\ w) \"\ s*,?)*] 원래 질문에서 시도했습니다. 모든 값을 얻으려면 전체 배열의 내용을 캡처 한 다음 캡처 된 컨텐츠에서 2 차 처리를 수행해야합니다.
개선 된 정규 표현 : "값"\ s*: \ s*\ [(.)]
이 정규 표현의 아이디어는 다음과 같습니다.
- "값"\ s*: \ s*\ [: 일치 "값": [섹션, 여기서 \ s*는 0 이상의 공백과 일치합니다.
- (.) : 이것은 사용하는 캡처 그룹입니다. 모든 캐릭터 (라인 브레이크 제외)와 일치시키기 위해 한 번 이상. 만나기 전까지는 가능한 한 여러 번 일치합니다]. 이것은 "ABC123", "def456", "xyz789"와 같은 전체 배열 내부의 문자열 내용을 캡처합니다.
- ] : 배열의 끝 괄호와 일치합니다.
Java 구현 :
import java.util.arrays; Java.util.list 가져 오기; import java.util.regex.matcher; java.util.regex.pattern import; Java.util.stream.collectors 가져 오기; 공개 클래스 regexjsonArrayExtractor { 개인 정적 문자열 소스 () { 문자열 s = "{\"value \ ": [\ n" "\"ABC123 \ ", \"def456 \ "," "\"xyz789 \ "] \ n" "}"; 반환 s; } public static void main (String [] args) { 문자열 JSONST = 소스 (); // 이것은 로그에서 얻은 JSON 문자열이라고 가정합니다. // 1 단계 : 정규 표현식을 사용하여 전체 배열 패턴의 내용을 캡처합니다. 패턴의 내용을 캡처하십시오. 매치 업체 매치 자 = Pattern1.matcher (JSONST); List <string> values = list.of (); // 빈 목록으로 초기화 if (matcher.find ()) { // mayser.group (1)은 "ABC123", "def456", "xyz789"와 같이 전체 배열 내부에 문자열이 포함됩니다. String arrayContent = matcher.group (1); // 2 단계 : 캡처 된 배열 컨텐츠 값을 분할하고 청소하고 청소하십시오. } System.out.println ( "정규 표현식으로 추출 된 값 :"); values.foreach (System.out :: println); /* * 출력 : * ABC123 * def456 * XYZ789 */ } }</string>
이 방법은 먼저 정규 표현식을 통해 JSON 어레이 내부의 모든 내용을 캡처 한 다음 Java의 문자열 처리 기능 (분할, 교체, 스트립)을 사용하여 각 값을 추출하고 정리합니다.
2.3 주목해야 할 것
- 열악한 견고성 : JSON 형식이 약간 변경되면이 정규식은 유효하지 않습니다 (예 : 값에는 쉼표, 따옴표 또는 중첩 구조가 포함되어 있음).
- 높은 유지 보수 비용 : JSON 구조가 변경되면 POJO 또는 JSONNODE 액세스 경로를 수정하는 것보다 훨씬 더 복잡한 정규식 및 후속 문자열 처리 로직을 수정해야합니다.
- 성능 : 매우 큰 문자열의 경우 빈번한 정규 표현식 일치 및 문자열 작업이 성능에 영향을 줄 수 있습니다.
3. 요약 및 제안
Java의 문자열에서 JSON 어레이 값을 추출 할 때 Jackson 또는 GSON과 같은 성숙한 JSON 구문 분석 라이브러리의 우선 순위를 정하는 것이 좋습니다.
- 구조 고정 JSON : POJO를 사용한 사제화, 유형-안전, 읽기 쉽고 유지하기 쉬운 코드를 제공합니다.
- 구조 동적 또는 부분적 인 부분 데이터의 경우 : 트리 파싱에 JSONNODE를 사용하여 유연성과 주문형 액세스를 제공합니다.
수동 추출은 JSON 구조가 매우 간단하고 형식이 매우 일관된 시나리오에서만 고려됩니다. 이 경우에도 잠재적 유지 보수 비용과 견고성 위험을 완전히 평가해야합니다. 올바른 도구를 선택하면 코드의 신뢰성, 가독성 및 향후 유지 관리 가능성이 보장됩니다.
위 내용은 Java의 문자열에서 JSON 어레이 값 추출에 대한 실용 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Stock Market GPT
더 현명한 결정을 위한 AI 기반 투자 연구

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

-CP 매개 변수를 사용하여 JVM이 ClassPath에 추가하여 JAVA -Clibrary.jarcom.example.Main과 같은 내부 클래스 및 리소스를로드 할 수 있으며, 이는 세미콜론 또는 콜론으로 분리 된 여러 항아리를 지원하며 클래스 경로 환경 변수 또는 Manifest.MF를 통해 구성 할 수 있습니다.

usefile.createnewfile () to reatefileonlyifitdoesn'texist, 피하기;

Amplements 키워드를 사용하여 인터페이스를 구현하십시오. 이 클래스는 인터페이스에서 모든 메소드의 특정 구현을 제공해야합니다. 여러 인터페이스를 지원하고 메소드가 공개되도록 쉼표로 분리됩니다. Java 8 이후의 기본 및 정적 메소드는 다시 작성할 필요가 없습니다.

Javaspi는 JDK의 내장 서비스 검색 메커니즘이며 Serviceloader를 통한 인터페이스 지향 동적 확장을 구현합니다. 1. 서비스 인터페이스를 정의하고 Meta-Inf/Services/에서 인터페이스의 전체 이름을 가진 파일을 작성하고 구현 클래스의 정규화 된 이름을 작성하십시오. 2. serviceloader.load ()를 사용하여 구현 클래스를로드하면 JVM은 자동으로 구성을 읽고 인스턴스화합니다. 3. 인터페이스 계약은 설계 중에 명확 해지고 우선 순위 및 조건부로드를 지원하며 기본 구현을 제공해야합니다. 4. 응용 프로그램 시나리오에는 다중 지불 채널 액세스 및 플러그인 확인이 포함됩니다. 5. 성능, 클래스 경로, 예외 분리, 스레드 안전 및 버전 호환성에주의하십시오. 6. Java9에서는 모듈 시스템과 함께 제공 될 수 있습니다.

이 기사에서는 동일한 TCP 소켓, 즉 HTTP 영구 연결 (Keep-Alive)에서 여러 HTTP 요청을 전송하는 메커니즘을 심층적으로 살펴 봅니다. 이 기사는 HTTP/1.X와 HTTP/2 프로토콜의 차이를 명확히하고 지속적인 연결에 대한 서버 측 지원의 중요성과 연결을 올바르게 처리하는 방법 : 응답 헤더를 정확하게 처리하는 방법을 강조합니다. 일반적인 오류를 분석하고 모범 사례를 제공함으로써 개발자가 효율적이고 강력한 HTTP 클라이언트를 구축 할 수 있도록 도와줍니다.

javagenericsprovidecompile-timetypesafetyandeliminatecastingtypeparametersonclasses, interfaces, methods; wildcards (?,? extendStype,? supertype) handlUnknowntypeswithflexible.1.useUnunUnunUndwildCardWhentyPeiLISIRVENTERREATHERNEATHEATHEATHEATHEATHEATHEATHEATHEATHEARVENTOUBERDERRELOUNTERRELONTERREATHEARBERBERBENTECASTS;

속성 클래스를 사용하여 Java 구성 파일을 쉽게 읽으십시오. 1. config.properties를 리소스 디렉토리에 넣고 getClassLoader (). getResourCeasStream ()을 통해로드하고로드 () 메서드를 호출하여 데이터베이스 구성을 읽습니다. 2. 파일이 외부 경로에있는 경우 FileInputStream을 사용하여로드하십시오. 3. GetProperty (키, 기본값)를 사용하여 누락 된 키를 처리하고 기본값을 제공하여 예외 처리 및 입력 확인을 보장합니다.

이 튜토리얼은 Java의 다른 배열 목록을 포함하는 중첩 된 배열 목록을 효율적으로 처리하고 모든 내부 요소를 단일 배열로 병합하는 방법을 자세히 설명합니다. 이 기사는 Java 8 Stream API의 FlatMap 작동을 통해 두 가지 핵심 솔루션을 제공합니다. 첫 번째는 목록으로 평평한 다음 배열을 채우고 다른 시나리오의 요구를 충족시키기 위해 새로운 배열을 직접 작성합니다.
