CLIEN

본문 바로가기 메뉴 바로가기 보기설정 테마설정
톺아보기 공감글
커뮤니티 커뮤니티전체 C 모두의광장 F 모두의공원 I 사진게시판 Q 아무거나질문 D 정보와자료 N 새로운소식 T 유용한사이트 P 자료실 E 강좌/사용기 L 팁과강좌 U 사용기 · 체험단사용기 W 사고팔고 J 알뜰구매 S 회원중고장터 B 직접홍보 · 보험상담실 H 클리앙홈
소모임 소모임전체 ·굴러간당 ·아이포니앙 ·주식한당 ·MaClien ·방탄소년당 ·일본산당 ·개발한당 ·자전거당 ·소시당 ·이륜차당 ·AI당 ·골프당 ·안드로메당 ·소셜게임한당 ·콘솔한당 ·걸그룹당 ·나스당 ·키보드당 ·곰돌이당 ·퐁당퐁당 ·가상화폐당 ·바다건너당 ·리눅서당 ·노젓는당 ·위스키당 ·갖고다닌당 ·클다방 ·디아블로당 ·라즈베리파이당 ·찰칵찍당 ·육아당 ·3D메이킹 ·X세대당 ·ADHD당 ·AI그림당 ·날아간당 ·사과시계당 ·배드민턴당 ·야구당 ·농구당 ·블랙베리당 ·비어있당 ·FM당구당 ·블록체인당 ·보드게임당 ·활자중독당 ·볼링친당 ·캠핑간당 ·냐옹이당 ·문명하셨당 ·클래시앙 ·요리한당 ·쿠키런당 ·대구당 ·DANGER당 ·뚝딱뚝당 ·개판이당 ·동숲한당 ·날아올랑 ·전기자전거당 ·e북본당 ·이브한당 ·패셔니앙 ·물고기당 ·도시어부당 ·FM한당 ·맛있겠당 ·포뮬러당 ·젬워한당 ·안경쓴당 ·차턴당 ·총쏜당 ·땀흘린당 ·하스스톤한당 ·히어로즈한당 ·인스타한당 ·IoT당 ·KARA당 ·꼬들한당 ·덕질한당 ·어학당 ·가죽당 ·레고당 ·LOLien ·Mabinogien ·임시소모임 ·미드당 ·밀리터리당 ·땅판당 ·헌팅한당 ·오른당 ·영화본당 ·MTG한당 ·소리당 ·노키앙 ·적는당 ·방송한당 ·PC튜닝한당 ·그림그린당 ·소풍간당 ·심는당 ·패스오브엑자일당 ·품앱이당 ·리듬탄당 ·달린당 ·Sea마당 ·SimSim하당 ·심야식당 ·윈태블릿당 ·미끄러진당 ·축구당 ·나혼자산당 ·스타한당 ·스팀한당 ·파도탄당 ·테니스친당 ·테스트당 ·빨콩이당 ·공대시계당 ·여행을떠난당 ·터치패드당 ·트윗당 ·창업한당 ·VR당 ·시계찬당 ·WebOs당 ·와인마신당 ·WOW당 ·윈폰이당
임시소모임
고객지원
  • 게시물 삭제 요청
  • 불법촬영물등 신고
  • 쪽지 신고
  • 닉네임 신고
  • 제보 및 기타 제안
© CLIEN.NET
공지[점검] 잠시후 서비스 점검을 위해 약 30분간 접속이 차단됩니다. (금일 18:15 ~ 18:45)

팁과강좌

PDA 애플과 유튜브 뮤직 가수-앨범-노래 순 정렬하기

1
2026-05-05 13:26:07 수정일 : 2026-05-05 13:46:33 58.♡.123.180
애니콜라

노래 리스트를  가수-앨범-노래 순으로 정렬 안하면 안되는 병이 있어서 

그동안 메론만 썼는데 (구형 멜론 프로그램은 가능합니다.)

멜론에 한 맺힌 게 많아서 알아보다 

애플은 직접 어플 뒤져서 찾았고, 

유튜브 뮤직은 깃헙에 있는 거 실행이 안돼서 ai한테 도움 받아 수정한 방법입니다.

(https://sagwatteok.tistory.com/m/41)

생각보다 다중 정렬 방법은 찾기 힘들더라구요.

아카이브 겸 필요하실 분 있을까봐 올립니다.


■ 애플 뮤직 (어플)

 1. 오른쪽 위 정렬 버튼 클릭 

 2. 다음으로 보기 – 노래 클릭

 3. 노래 – 앨범 – 연도 – 아티스트 순으로 정렬

 4. 오른쪽 설정 버튼(…) 클릭

 5. 재생순서대로 복사 ★ 필수

 6. 플레이리스트 복사 ★ 어쩌면 불필요할 수도 있지만 확실히 하기 위한 방법


■  유튜브 뮤직 (웹)

1. 사전 설정 

  - 크롬 확장프로그램 Tampermonkey 설치

  - 확장앱 관리 – 권한 – 사용자 스크립트 허용 & 사이트 엑세스 (https://music.youtube.com) 입력

  - 권한 문제로 보안 위험 있음 (사용 시에만 Tampermonkey 활성화 조치 / 개인 선택)


2. Tampermonkey  설정

  - Tampermonkey 클릭

  - 대시보드 클릭

  - 상부 메뉴 + 선택

  - 아래 스크립트 입력 및 저장

    ※ 여러 이유로 안되시면 ai의 도움을 받아보세요;;


3. 스크립트

// ==UserScript==

// @name         YTMusic Safe Playlist Sort (Strict No Recs)

// @namespace    http://tampermonkey.net/

// @version      3.1

// @include      https://music.youtube.com/*

// @grant        none

// @run-at       document-end

// ==/UserScript==


(function () {

  'use strict';


  let lastUrl = location.href;


  // ======================

  // 재생목록 영역만 선택 (핵심)

  // ======================


  function getPlaylistContainer() {

    return document.querySelector('ytmusic-playlist-shelf-renderer');

  }


  function getItems() {

    const container = getPlaylistContainer();

    if (!container) return [];


    const mainListContents = container.querySelector('#contents');

    if (!mainListContents) return [];


    const items = Array.from(

      mainListContents.querySelectorAll(':scope > ytmusic-responsive-list-item-renderer')

    );


    return items.filter(item => item.querySelector('yt-formatted-string.title'));

  }


  // ======================

  // 텍스트 추출

  // ======================


  function getTitle(item) {

    return item.querySelector('yt-formatted-string.title')?.textContent.trim() ?? '';

  }


  function getSecondaryTexts(item) {

    return Array.from(

      item.querySelectorAll('.secondary-flex-columns yt-formatted-string')

    )

      .map(el => el.textContent.trim())

      .filter(Boolean);

  }


  function getArtist(item) {

    return getSecondaryTexts(item)[0] ?? '';

  }


  function getAlbum(item) {

    return getSecondaryTexts(item)[1] ?? '';

  }


  // ======================

  // 정렬 기준

  // ======================


  function getType(str) {

    if (!str) return 3;


    const ch = str.trim()[0];


    if (/[A-Za-z]/.test(ch)) return 0; // 영어

    if (/[가-힣]/.test(ch)) return 1;   // 한글

    if (/[0-9]/.test(ch)) return 2;     // 숫자


    return 3; // 기타

  }


  function compareSmart(a, b) {

    const ta = getType(a);

    const tb = getType(b);


    if (ta !== tb) return ta - tb;


    return String(a).localeCompare(String(b), 'ko', {

      numeric: true,

      sensitivity: 'base'

    });

  }


  // ======================

  // 정렬 실행

  // ======================


  function sortPlaylist() {

    const items = getItems();

    const container = getPlaylistContainer();

    const mainListContents = container ? container.querySelector('#contents') : null;


    if (!mainListContents || items.length === 0) {

      alert('정렬할 재생목록 곡을 찾지 못했습니다. (추천 곡은 무시됨)');

      return;

    }


    const beforeCount = items.length;


    const sorted = [...items].sort((a, b) => {

      let cmp = compareSmart(getArtist(a), getArtist(b));

      if (cmp !== 0) return cmp;


      cmp = compareSmart(getAlbum(a), getAlbum(b));

      if (cmp !== 0) return cmp;


      return compareSmart(getTitle(a), getTitle(b));

    });


    const fragment = document.createDocumentFragment();

    sorted.forEach(item => fragment.appendChild(item));


    mainListContents.appendChild(fragment);


    const afterCount = getItems().length;


    if (beforeCount !== afterCount) {

      alert(

        `정렬 완료 (주의)\n` +

        `정렬 전: ${beforeCount}\n` +

        `정렬 후: ${afterCount}`

      );

    } else {

      alert(`내 곡 정렬 완료 (${afterCount}곡) - 추천 곡 제외됨`);

    }

  }


  // ======================

  // UI

  // ======================


  function injectUI() {

    if (!location.href.includes('list=')) return;

    if (document.getElementById('ytmusic-sort-ui')) return;


    const bar = document.createElement('div');

    bar.id = 'ytmusic-sort-ui';


    bar.style.cssText = `

      position:fixed;

      top:90px;

      right:20px;

      z-index:2147483647;

      background:#222;

      color:#fff;

      padding:10px;

      border-radius:10px;

      display:flex;

      flex-direction:column;

      gap:6px;

      box-shadow:0 2px 12px rgba(0,0,0,0.55);

      font-family:Arial,sans-serif;

    `;


    const sortBtn = document.createElement('button');

    sortBtn.textContent = '정렬';

    sortBtn.style.cssText = `

      padding:7px 10px;

      cursor:pointer;

      border-radius:4px;

      border:1px solid #555;

      background:#333;

      color:#fff;

      font-weight:bold;

    `;

    sortBtn.onclick = sortPlaylist;


    const closeBtn = document.createElement('button');

    closeBtn.textContent = '닫기';

    closeBtn.style.cssText = sortBtn.style.cssText;

    closeBtn.style.fontWeight = 'normal';

    closeBtn.onclick = () => bar.remove();


    bar.appendChild(sortBtn);

    bar.appendChild(closeBtn);


    document.body.appendChild(bar);

  }


  function boot() {

    injectUI();

  }


  window.addEventListener('load', () => {

    setTimeout(boot, 1000);

    setTimeout(boot, 3000);

  });


  setTimeout(boot, 1000);

  setTimeout(boot, 3000);


  setInterval(() => {

    if (location.href !== lastUrl) {

      lastUrl = location.href;

      setTimeout(boot, 1000);

      setTimeout(boot, 3000);

    }

    boot();

  }, 2000);

})();

애니콜라 님의 게시글 댓글
  • 주소복사
  • Facebook
  • X(Twitter)
댓글 • [0]
새로운 댓글이 없습니다.
이미지 최대 업로드 용량 15 MB / 업로드 가능 확장자 jpg,gif,png,jpeg,webp
지나치게 큰 이미지의 크기는 조정될 수 있습니다.
목록으로
글쓰기
글쓰기
목록으로 댓글보기 이전글 다음글
아이디  ·  비밀번호 찾기 회원가입
이용규칙 운영알림판 운영소통 재검토요청 도움말 버그신고
개인정보처리방침 이용약관 책임의 한계와 법적고지 청소년 보호정책
©   •  CLIEN.NET
보안 강화를 위한 이메일 인증
안전한 서비스 이용을 위해 이메일 인증을 완료해 주세요. 현재 회원님은 이메일 인증이 완료되지 않은 상태입니다.
최근 급증하는 해킹 및 도용 시도로부터 계정을 보호하기 위해 인증 절차가 강화되었습니다.

  • 이메일 미인증 시 글쓰기, 댓글 작성 등 게시판 활동이 제한됩니다.
  • 이후 새로운 기기에서 로그인할 때마다 반드시 이메일 인증을 거쳐야 합니다.
  • 2단계 인증 사용 회원도 최초 1회는 반드시 인증하여야 합니다.
  • 개인정보에서도 이메일 인증을 할 수 있습니다.
지금 이메일 인증하기
등록된 이메일 주소를 확인하고 인증번호를 입력하여
인증을 완료해 주세요.