textlint-rule-preset-ai-writing
v1.1.0
Published
textlintプリセット:AIっぽい記述パターンを検出し、より自然な日本語表現を促すルール集
Maintainers
Readme
textlint-rule-preset-ai-writing
AIが生成した文章によく見られる記述パターンを検出します。 より自然な日本語表現を促すtextlintルールプリセットです。
原則
表現を縛るのではなく、構造を縛ることで、より自然な表現にすることを目的としています。
バージョニング方針
このプリセットは次のバージョニングでアップデートします。
- patch(パッチバージョン): ルールの修正
- エラーメッセージの改善
- 既存ルールの検出精度向上
- バグ修正
- 注意: ルール修正によりエラーが増える場合もありますが、これもpatchとして扱います
- minor(マイナーバージョン): ルールの追加
- 新しいルールの追加
- 新しいオプションの追加
- major(メジャーバージョン): ルールの削除
- 既存ルールの削除
- 破壊的変更
ルール修正(patch)でもエラー数は変動する可能性があります。更新時はpackage-lock.jsonやyarn.lockなどのロックファイルの利用を推奨します。
含まれるルール
1. no-ai-list-formatting
リストアイテムで機械的な印象を与える可能性のある記述パターンを検出します。
2. no-ai-hype-expressions
AIライティングで過度に使用されがちな誇張表現やハイプ的な表現を検出します。
3. no-ai-emphasis-patterns
AIが機械的に生成しがちな強調パターンを検出します。
4. ai-tech-writing-guideline
テクニカルライティングのベストプラクティスに基づいて、文書品質の改善提案を行います。 詳細なガイドラインについては docs/tech-writing-guidelines.md を参照してください。
推奨する組み合わせ
このルールは textlint-rule-preset-ja-technical-writing との組み合わせを推奨します。
ja-technical-writing はfalse positiveが少ない確実なルールセットで、基本的な日本語技術文書の品質を担保します。
本ルール(ai-tech-writing-guideline)は、より高度な文書品質向上のためのサジェストとして使用することを想定しています。
検出される内容
- 簡潔性: 冗長表現の排除
まず最初に → まず 〜することができます → 〜します - 明確性: 能動態の使用推奨(受動態から能動態への変更提案)
- 具体性: 抽象的表現の具体化(「高速な」→「50ms未満の」など)
- 一貫性: 用語と表現の統一(同一対象への異なる用語使用の検出)
- 構造化: 文の長さと情報整理(長い文の分割提案など)
4-1. リストアイテムの強調表現
allows: 指定したパターンにマッチする場合、エラーを報告しません- 文字列:
"許可したいテキスト" - 正規表現:
"/パターン/フラグ"(例:"/以下のような.*/")
- 文字列:
no-ai-hype-expressions
allows: 指定したパターンにマッチする場合、エラーを報告しません- 文字列:
"許可したいテキスト" - 正規表現:
"/パターン/フラグ"(例:"/革命的な.*/")
- 文字列:
disableAbsolutenessPatterns:trueにすると絶対性・完全性を演出する表現の検出を無効にするdisableAbstractPatterns:trueにすると抽象的・感覚的効果を演出する表現の検出を無効にするdisabledPredictivePatterns:trueにすると権威的・予言的な表現の検出を無効にしますパターン
検出される例:
- **重要**: これは重要な項目です
- **注意**: 注意が必要な項目です書き換えた例:
- 重要な項目: これは重要な項目です
- 注意事項: 注意が必要な項目です- 注意事項: 注意が必要な項目です
#### 1-2. 絵文字を使ったリストアイテム
AIが機械的に使いがちな装飾的な絵文字の使用を検出します。
検出対象は、特に「華やか」で機械的な印象を与える絵文字に限定されています。
検出される例:
```markdown
- ✅ 完了した項目
- ❌ 失敗した項目
- 💡 アイデア項目
- 🔥 ホットな話題
- 🚀 開始準備完了
- ⭐ 重要項目
- 🎯 目標設定
- 📝 メモ項目書き換えた例:
- 完了した項目
- 失敗した項目
- アイデア項目
- 注目の話題
- 開始準備完了
- 重要項目
- 目標設定
- メモ項目注意: 普通の絵文字(😀, 🍎, 🐱, 🌸など)は検出されません。
2. no-ai-hype-expressions
AIライティングで過度に使用されがちな誇張表現やハイプ的な表現を検出します。自然で読みやすい文章を促進するためのルールです。
3-1. 絶対性・完全性を演出する表現
検出される例:
革命的な技術で業界を変えます。
これはゲームチェンジャーです。
世界初のソリューションを提供します。
究極のパフォーマンスを実現します。
完全に問題を解決します。
すべての課題を解決します。
最高の品質を保証します。書き換えた例:
効果的な技術で業界に変化をもたらします。
これは大きな変化をもたらすでしょう。
新しいソリューションを提供します。
高いパフォーマンスを実現します。
多くの問題を解決します。
主要な課題を解決します。
高い品質を保証します。3-2. 抽象的・感覚的効果を演出する表現
検出される例:
魔法のように動作します。
奇跡的な結果を生み出します。
可能性を解き放つソリューションです。
AIを民主化するプラットフォームです。
業務をスーパーチャージします。書き換えた例:
スムーズに動作します。
優れた結果を生み出します。
新たな機会を創出するソリューションです。
AIを利用しやすくするプラットフォームです。
業務を効率化します。3-3. 権威的・予言的な表現
検出される例:
業界を再定義する革新です。
未来を変える技術です。
パラダイムシフトを起こします。
不可避の変化が起こります。
次世代のソリューションです。書き換えた例:
業界に新しい視点をもたらす革新です。
将来に影響を与える技術です。
大きな変化を起こします。
重要な変化が起こるでしょう。
新しいソリューションです。Install
Install with npm:
npm install textlint-rule-preset-ai-writingRequirements
- textlint 15.1.0以降が必要です
Usage
Via .textlintrc(Recommended)
{
"rules": {
"preset-ai-writing": true
}
}推奨構成: ja-technical-writing との組み合わせ
基本的な日本語技術文書の品質担保と、より高度な文書品質向上の組み合わせ:
{
"rules": {
"preset-ja-technical-writing": true,
"preset-ai-writing": {
"ai-tech-writing-guideline": {
"severity": "info"
}
}
}
}この構成では、ja-technical-writing で確実な問題を修正し、ai-tech-writing-guideline でさらなる改善提案を受け取ることができます。
Options
各ルールに対して個別にオプションを設定できます。
{
"rules": {
"preset-ai-writing": {
"no-ai-list-formatting": {
"allows": ["許可したいテキスト", "/正規表現パターン/i"],
"disableBoldListItems": false,
"disableEmojiListItems": false
},
"no-ai-hype-expressions": {
"allows": ["許可したいテキスト", "/正規表現パターン/"],
"disableAbsolutenessPatterns": false,
"disableAbstractPatterns": false,
"disabledPredictivePatterns": false
},
"ai-tech-writing-guideline": {
"severity": "info", // サジェストとして扱う
"allows": ["許可したいテキスト", "/正規表現パターン/"],
"disableRedundancyGuidance": false,
"disableVoiceGuidance": false,
"disableClarityGuidance": false,
"disableConsistencyGuidance": false,
"disableStructureGuidance": false,
"enableDocumentAnalysis": true
}
}
}
}Options説明
no-ai-list-formatting
allows: 指定したパターンにマッチする場合、エラーを報告しません- 文字列:
"許可したいテキスト" - 正規表現:
"/パターン/フラグ"(例:"/重要.*/i")
- 文字列:
disableBoldListItems:trueにすると強調リストアイテムの検出を無効にするdisableEmojiListItems:trueにすると絵文字リストアイテムの検出を無効にする
正規表現パターンの使用例
allowsオプションでは、regexp-string-matcherの形式で正規表現パターンを指定できます。
基本的な使い方
{
"allows": [
"特定の文字列", // 完全一致
"/パターン/", // 正規表現(基本)
"/パターン/i", // 大文字小文字を無視
"/パターン/m" // 複数行マッチ
]
}実用例
{
"allows": [
"/重要.*/", // 「重要」で始まる任意の文字列
"/\\*\\*注意\\*\\*/", // **注意** (特殊文字をエスケープ)
"/TODO.*/i", // TODO で始まる文字列(大文字小文字無視)
"/\\d{4}-\\d{2}-\\d{2}/" // 日付形式 (YYYY-MM-DD)
]
}Via CLI
textlint --rule @textlint-ja/no-ai-writing README.mdChangelog
See Releases page.
Running tests
Install devDependencies and Run npm test:
npm i -d && npm testContributing
Pull requests and stars are always welcome.
For bugs and feature requests, please create an issue.
- Fork it
- Create your feature branch:
git checkout -b my-new-feature - Commit your changes:
git commit -am 'Add some feature' - Push to the branch:
git push origin my-new-feature - Submit a pull request :D
Author
License
MIT © azu
