技能 编程开发 macOS 苹果备忘录自动化

macOS 苹果备忘录自动化

v20260423
apple-notes-install-auth
本技能集提供了在macOS上自动化管理苹果备忘录的完整指南。由于苹果备忘录缺乏REST API,本工具侧重于指导用户设置必要的系统权限,并通过AppleScript、JXA和快捷指令等系统级技术,实现笔记的读取、批量操作和复杂工作流自动化。
获取技能
222 次下载
概览

Apple Notes Install & Auth

Overview

Apple Notes has no REST API. Automation uses macOS scripting technologies: AppleScript, JavaScript for Automation (JXA), Shortcuts, and the osascript command-line tool. No SDK to install — but you need macOS accessibility permissions.

Prerequisites

  • macOS 13+ (Ventura or later recommended)
  • Terminal app or iTerm2
  • System Preferences > Privacy & Security > Automation permissions

Instructions

Step 1: Grant Automation Permissions

# macOS requires explicit permission for scripts to control Notes.app
# The first time you run an osascript command targeting Notes, macOS will prompt.
# You can also pre-grant in: System Preferences > Privacy & Security > Automation

# Test basic Notes access (will trigger permission prompt)
osascript -e 'tell application "Notes" to get name of every note in default account'

Step 2: Verify JXA (JavaScript for Automation) Access

# JXA is the modern alternative to AppleScript
# Run JavaScript via osascript with -l JavaScript flag

osascript -l JavaScript -e '
  const Notes = Application("Notes");
  Notes.includeStandardAdditions = true;
  const noteCount = Notes.defaultAccount.notes.length;
  `Apple Notes accessible: ${noteCount} notes found`;
'

Step 3: Create a Wrapper Script

#!/bin/bash
# scripts/notes-cli.sh — Wrapper for common Apple Notes operations

case "$1" in
  count)
    osascript -l JavaScript -e '
      const Notes = Application("Notes");
      Notes.defaultAccount.notes.length;
    '
    ;;
  list)
    osascript -l JavaScript -e '
      const Notes = Application("Notes");
      const notes = Notes.defaultAccount.notes();
      notes.slice(0, 20).map(n => `${n.id()} | ${n.name()}`).join("\n");
    '
    ;;
  folders)
    osascript -l JavaScript -e '
      const Notes = Application("Notes");
      Notes.defaultAccount.folders().map(f => f.name()).join("\n");
    '
    ;;
  *)
    echo "Usage: notes-cli.sh {count|list|folders}"
    ;;
esac

Step 4: Verify Shortcuts Integration

# Apple Shortcuts can also interact with Notes
# Check available shortcuts
shortcuts list | grep -i note

# Run a shortcut that creates a note
shortcuts run "Create Note" --input-path /dev/stdin <<< "Test content"

Automation Technologies

Technology Language Best For Docs
AppleScript AppleScript Simple operations Apple Scripting Guide
JXA JavaScript Complex logic, JSON handling Apple JXA Reference
osascript CLI wrapper Scripts, CI/CD man osascript
Shortcuts Visual Non-developer workflows Shortcuts app
PyXA Python Python automation pyxa.dev

Output

  • macOS automation permissions granted for Notes.app
  • JXA access verified with note count
  • CLI wrapper script for common operations
  • Shortcuts integration confirmed

Error Handling

Error Cause Solution
Not authorized to send Apple events Missing automation permission Grant in System Preferences > Privacy > Automation
Notes got an error: AppleEvent timed out Notes.app not running Launch Notes first or add activate
-1743 errAEAppNotAllowed Denied by TCC Reset TCC: tccutil reset AppleEvents
execution error: Notes is not running Notes.app closed Add tell app "Notes" to activate

Resources

Next Steps

Proceed to apple-notes-hello-world for your first note creation.

信息
Category 编程开发
Name apple-notes-install-auth
版本 v20260423
大小 4.38KB
更新时间 2026-04-28
语言