디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

linq 다른언어용으로 비슷하게 만든거앱에서 작성

발명도둑잡기(118.216) 2025.11.26 18:27:08
조회 103 추천 0 댓글 2

챗지피티
LINQ와 비슷한 개념(쿼리식/함수형 컬렉션 처리)을 다른 언어에서 구현한 것들을 정리해줄게.
핵심은 “컬렉션/객체에 대해 선언적 쿼리 스타일로 변환·필터·집계”를 제공하는 기능들이다.

LINQ와 가장 유사한 기능을 가진 언어들

1) Java – Stream API

LINQ 영향 가장 크게 받은 기능

list.stream() .filter(x -> x > 10) .map(x -> x * 2) .collect(Collectors.toList());

지연 실행(Lazy)

Select/Where/GroupBy와 매우 비슷

단, 쿼리 문법은 없고 메서드 체이닝 방식

2) – Array Methods / Lodash

기본 내장 메서드

arr.filter(x => x > 10).map(x => x * 2)

Lodash도 Map/Filter/Reduce를 확장한 LINQ 느낌의 라이브러리

_.chain(arr).filter(...).map(...).value();

3) Python – List Comprehension / itertools / pandas

List Comprehension

[x*2 for x in arr if x > 10]

itertools (지연 실행)

filter(lambda x: x > 10, arr)

pandas → SQL/LINQ와 거의 동일

df[df.age > 30].groupby("city").mean()

4) Kotlin – Sequence / Collections API

list.filter { it > 10 }.map { it * 2 }

Java Stream보다 직관적

LINQ와 구조적으로 매우 유사

5) Scala – Collections / Lazy Streams

arr.filter(_ > 10).map(_ * 2)

완전 함수형 스타일로 LINQ와 상당히 가까움.

6) Rust – Iterator

arr.ㅡiter() .filter(|x| *x > 10) .map(|x| x * 2) .collect::<Vec<_>>();

지연 실행 + 체이닝 = LINQ와 매우 유사.

7) F# – Seq / List / Array modules

arr |> Seq.filter (fun x -> x > 10) |> Seq.map (fun x -> x * 2)

C#과 같은 .NET 패밀리라 LINQ와 거의 동일한 철학 공유.

8) Swift – Functional Sequence API

arr.filter { $0 > 10 }.map { $0 * 2 }

9) Ruby – Enumerable

arr.select { |x| x > 10 }.map { |x| x * 2 }

“LINQ 자체를 다른 언어로 포팅한 프로젝트”

“LINQ를 흉내 낸 라이브러리”들도 있다:

라이브러리언어특징jinqJavaLINQ 스타일 APIlinq.jsC# LINQ를 거의 그대로 구현RxJS / RxJavaJS / JavaLINQ to s + LINQ to Events 철학morelinqC#LINQ 확장linq4jJavaApache Calcite 기반, SQL 같은 쿼리 가능

결론

LINQ는 독자적인 문법(Query Syntax)까지 가진 특이한 성공 사례지만,
“컬렉션을 쿼리하듯 다루는 함수형 API”는 거의 모든 현대 언어가 제공한다.

가장 LINQ스럽다고 평가되는 언어 TOP 3

Java Stream

Kotlin Sequence

Scala Collections

필요하다면
각 언어별 LINQ 대응 표,
LINQ 스타일 DSL 만들기,
C# LINQ 기능을 다른 언어로 포팅하는 방법
도 만들어줄까?

좋아, C# LINQ처럼 동작하는 DSL(도메인 특화 언어)을 만드는 방법
*“직접 구현 가능한 최소 예제 + 확장 방식”*까지 아주 구체적으로 정리해줄게.

아래는 언어 불문 공통 설계 원리 → 예제 구현(파이썬/자바스크립트/자바 중 선택형) → 확장 패턴 순서로 설명한다.

1. LINQ DSL의 핵심 개념 4가지

LINQ는 크게 다음 4개만 구현하면 “동작하는 DSL”이 된다:

① Enumerable(Sequence) 타입

내부적으로 iterable 보관

지연 실행 또는 즉시 실행 중 선택

② 연산자 (Where, Select, GroupBy…)

함수 체이닝 지원

식(expression)을 인자로 받음

새로운 Sequence 리턴 → 불변성 유지

③ 쿼리 엔진

체인된 연산자를 순서대로 평가

Lazy evaluation을 하면 성능이 매우 비슷해짐

④ (선택) Query Syntax → Method Syntax 변환기

C#은

from x in data where x > 10 select x * 2

을 내부적으로

data.Where(x => x > 10).Select(x => x * 2)

로 바꾼다.
이건 선택 사항.

2. 최소 기능 LINQ DSL을 직접 구현하기 (언어 무관 알고리즘)

Sequence 클래스 구조

Sequence { source : iterable ops : list of operations where(func) select(func) toList() }

Lazy pipeline

각 연산을 “기계적으로” 이어붙이면 된다:

ops = [ ("where", lambda x: x > 10), ("select", lambda x: x * 2), ]

평가할 때:

for item in source: if all where(item): item = select(item) yield item

3. 완전 작동하는 실제 DSL 구현 예제

언어 하나 고르는 대신 가장 짧고 명확한 파이썬 버전을 기준으로 보여줄게.
(원하면 Java 또는 JS로도 만들어줄게.)

파이썬 LINQ DSL 구현 (Lazy)

class Query: def __init__(self, source): self.source = source self.ops = [] def where(self, func): self.ops.append(("where", func)) return self def select(self, func): self.ops.append(("select", func)) return self def __iter__(self): for item in self.source: ok = True value = item for op, fn in self.ops: if op == "where": if not fn(value): ok = False break elif op == "select": value = fn(value) if ok: yield value def toList(self): return list(iter(self))

사용법

q = Query([1,2,3,4,5,6]) \ .where(lambda x: x % 2 == 0) \ .select(lambda x: x * 10) print(q.toList()) # [20, 40, 60]

LINQ의 핵심 형태를 그대로 재현했다.

4. “쿼리 문법”까지 만들기 (선택)

C#의 LINQ Query Syntax처럼 만들고 싶다면
아래 같은 "미니 파서"를 만들면 된다.

예시 문법:

from x in data where x > 10 select x * 2

파서 아이디어:

def parse(query_string, env): # 라인별로 분해 # 변수명 / source / 조건 / 선택 식 파싱 # ast로 변환 후 Query(...) 메서드 체인으로 출력

가능한 단순 구현 예:

def linq(q, env): lines = [l.strip() for l in q.strip().split("\n")] var, src = lines[0].split()[1], env[lines[0].split()[3]] query = Query(src) for line in lines[1:]: if line.startswith("where"): expr = line[len("where "):] query = query.where(lambda x, e=expr: [...]) elif line.startswith("select"): expr = line[len("select "):] query = query.select(lambda x, e=expr: [...]) return query

사용:

dsl = """ from x in data where x % 2 == 0 select x * 10 """ print(linq(dsl, {"data": [1,2,3,4,5,6]}).toList())

5. DSL 확장 포인트

이후에는 다음 것들을 추가할 수 있다.

• Join

Cross product + 필터

• GroupBy

키→아이템 리스트 dict 만들어서 Sequence로 감쌈

• OrderBy / ThenBy

파이프라인 마지막에서 sort

• SelectMany

flatMap

• Aggregate / Sum / Min / Max

즉시 평가 함수

• Deferred vs Immediate Execution 선택

실제 LINQ와 동일한 구조 구현 가능

원하면 더 만들어줄 수 있는 것

아래 중에 원하는 걸 말해줘:

Java 스타일 Stream 기반 DSL

용 LINQ.js 직접 구현

C# LINQ 기능 30개 전부 지원하는 DSL 풀버전

Query Syntax를 미니 SQL처럼 확장

타입 안전 LINQ DSL (Kotlin/TS)

어떤 스타일로 계속 만들어줄까?


추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 이제는 의미 없어진 것 같은 시상식은? 운영자 25/12/01 - -
AD 따뜻한 겨울나기! 방한용품 SALE 운영자 25/11/27 - -
2905240 러스트 러스트 러스트 러스트 러스트 러스트 프갤러(221.149) 11.28 56 0
2905239 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥멘헤라냥덩♥갤로그로 이동합니다. 11.28 61 0
2905238 내 컴터 상태가 이럴듯..ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 11.28 82 0
2905236 다들 이정도 정신문제는 가지지 않나 ㅇㅇ(39.7) 11.28 72 0
2905234 작년 이맘때 폭설 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 11.28 61 0
2905231 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 11.28 55 0
2905230 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 11.28 57 0
2905227 그레셤의 법칙이 더닝크루거에 선행한다 [29] chironpractor갤로그로 이동합니다. 11.28 124 0
2905224 맨날 뭐 망하라는 소리만 하면서 왜 자기가 애국자인척을 하지 ㅇㅇ갤로그로 이동합니다. 11.28 50 0
2905221 인지과학조져라 손발이시립디다갤로그로 이동합니다. 11.28 62 0
2905219 김영회 동국대 향가연구실장 "양주동 박사 향가 해독법 틀렸다" 발명도둑잡기(39.7) 11.28 51 0
2905218 일본 '만엽집' 대가 "일본은 아름다운 평화를 지향해야 한다" 발명도둑잡기(39.7) 11.28 46 0
2905217 양쪽 얘기 듣자는게 왜 역사왜곡임? [5] chironpractor갤로그로 이동합니다. 11.28 113 2
2905216 박원순 자ㅡ살 맞는지가 의문 [1] 발명도둑잡기(39.7) 11.28 67 0
2905215 스위스는 매달 전국민이 우편투표로 직접민주정치 발명도둑잡기(39.7) 11.28 48 0
2905214 ❤✨☀⭐⚡☘⛩☃나님 시작합니당☃⛩☘⚡⭐☀✨❤ ♥멘헤라냥덩♥갤로그로 이동합니다. 11.28 40 0
2905212 죽어가는 국민의힘 되살리는 기초의회 ‘2인 선거구’, 더 늘어나나 발명도둑잡기(39.7) 11.28 55 0
2905211 재명이 존나 찐따같네;; 카메라 보이니까 왕따 아닌척 발악;; [5] ♥멘헤라냥덩♥갤로그로 이동합니다. 11.28 85 0
2905210 진보당, 무주택자·세입자·청년의 ‘감당 가능한 주거’ 7대 정책 제안 [1] 발명도둑잡기(39.7) 11.28 63 0
2905208 경력기술서쓰는데 궁금한거 있음 [7] 프갤러(58.76) 11.28 102 0
2905207 미국 음반 시장 순위 조작을 위한 사재기 있나 발명도둑잡기(39.7) 11.28 137 0
2905203 <하우스 오브 다이너마이트> 인기래서 생각나는 예전 글 발명도둑잡기(39.7) 11.28 47 0
2905200 오늘의 소설, 영화 실마리: 초코파이 재판과 노조원 이야기 발명도둑잡기(39.7) 11.28 48 0
2905195 이익 배분 게임과 지능의 상관관계 [1] 발명도둑잡기(39.7) 11.28 88 0
2905193 넷마블 해킹 SQL 인젝션 추정 [1] ㅇㅇ(175.197) 11.28 99 0
2905191 넥스트 N.EX.T-Dear America 무삭제 발명도둑잡기(39.7) 11.28 50 0
2905190 아니 잼미니 미친년 지맘대로 배포 해버리네 ㅋㅋ 프갤러(218.236) 11.28 74 0
2905187 슈베르트-마왕 발명도둑잡기(39.7) 11.28 39 0
2905186 제리케이-마왕 발명도둑잡기(39.7) 11.28 39 0
2905185 요즘 어셈으로 짤 일이 많아서 그런가 [1] 루도그담당(58.233) 11.28 79 0
2905184 수이 블루비드 다녀옴 [1] 따당갤로그로 이동합니다. 11.28 76 0
2905181 나님 콧대가 그렇게 이뽀..? 따당갤로그로 이동합니다. 11.28 96 0
2905179 독도 간접 언급한 中, 포털사이트·AI도 “독도는 한국 땅” 발명도둑잡기(39.7) 11.28 50 0
2905178 페이커닮은 개발자 찾습니다 [2] 프갤러(106.101) 11.28 109 0
2905177 언리얼 메뉴얼 진짜 거지같네 [4] 프갤러(114.205) 11.28 89 0
2905175 개발하냐고 글 쓸 시간도 없고 ㅁㅌ겠네 ㅠㅠ [4] 나르시갤로그로 이동합니다. 11.27 66 0
2905174 세계최초의 최상위 수준 C API 래핑 설계 패턴인가? 나르시갤로그로 이동합니다. 11.27 80 0
2905173 N-Arity 제네릭 래퍼 + 중앙 집중식 예외 매퍼' 아키텍처 나르시갤로그로 이동합니다. 11.27 48 0
2905172 Clair 라이브러리: 예외 처리 C 바인딩 아키텍처 [1] 나르시갤로그로 이동합니다. 11.27 91 0
2905171 옛날에 nuri.net이 뭐였더라 발명도둑잡기(39.7) 11.27 52 0
2905170 중국 딥시크가 미국 AI 압살하는중 ㄷㄷ [4] ㅇㅇ갤로그로 이동합니다. 11.27 109 0
2905169 ‘성폭력 발언’ 이준석 불송치에…“막말 자유권은 없다” 반발 봇물 발명도둑잡기(39.7) 11.27 61 0
2905168 민주당, '2인선거구로 쪼개기'에 합세한다면 내란본당 국민의힘 부활 발명도둑잡기(39.7) 11.27 59 0
2905167 뭔가 소화가 잘 안된느낌 [2] ♥멘헤라냥덩♥갤로그로 이동합니다. 11.27 84 0
2905166 [애니뉴스] YxD Labs - 유튜브 링크 공유 ㅇㅇ(121.172) 11.27 49 0
2905165 MS 엣지브라우저 msn에 중요 노출되는 극우 황색지들 발명도둑잡기(39.7) 11.27 48 0
2905164 이세돌이 바둑 은퇴한거 이제 실감난다 [1] 프갤러(110.70) 11.27 75 0
2905163 컴퓨터로 일하는데 싸구려컴 쓰는 이유가 뭐임? [5] 에이도비갤로그로 이동합니다. 11.27 100 0
2905161 안타까운 점은 대충 아는 애들이 확신에 차있다는거임 [14] 박민준갤로그로 이동합니다. 11.27 126 3
2905160 50위권 밖에 있는 언어들은 대체 왜 만든거냐? [2] 두정갑(221.149) 11.27 81 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

디시미디어

디시이슈

1/2