تخطي إلى المحتوى

اللغة

اختر لغتك

انتقل إلى نفس الصفحة بلغة أخرى.

English English en Afrikaans Afrikaans af አማርኛ Amharic am العربية Arabic ar অসমীয়া Assamese as Azərbaycan Azerbaijani az Башҡорт Bashkir ba Български Bulgarian bg भोजपुरी Bhojpuri bho বাংলা Bangla bn བོད་སྐད་ Tibetan bo बड़ो Bodo brx Bosanski Bosnian bs Català Catalan ca Čeština Czech cs Cymraeg Welsh cy Dansk Danish da Deutsch German de डोगरी Dogri doi Dolnoserbšćina Lower Sorbian dsb ދިވެހިބަސް Divehi dv Ελληνικά Greek el Español Spanish es Eesti Estonian et Euskara Basque eu فارسی Persian fa Suomi Finnish fi Filipino Filipino fil Vakaviti Fijian fj Føroyskt Faroese fo Français French fr Français (Canada) French (Canada) fr-CA Gaeilge Irish ga Galego Galician gl कोंकणी Konkani gom ગુજરાતી Gujarati gu Hausa Hausa ha עברית Hebrew he हिन्दी Hindi hi छत्तीसगढ़ी Chhattisgarhi hne Hrvatski Croatian hr Hornjoserbsce Upper Sorbian hsb Haitian Creole Haitian Creole ht Magyar Hungarian hu Հայերեն Armenian hy Indonesia Indonesian id Ìgbò Igbo ig Inuinnaqtun Inuinnaqtun ikt Íslenska Icelandic is Italiano Italian it ᐃᓄᒃᑎᑐᑦ Inuktitut iu Inuktitut (Latin) Inuktitut (Latin) iu-Latn 日本語 Japanese ja ქართული Georgian ka Қазақ Тілі Kazakh kk ខ្មែរ Khmer km Kurmancî Kurdish (Northern) kmr ಕನ್ನಡ Kannada kn 한국어 Korean ko كٲشُر Kashmiri ks کوردیی ناوەندی Kurdish (Central) ku Кыргызча Kyrgyz ky Lëtzebuergesch Luxembourgish lb Lingála Lingala ln ລາວ Lao lo Lietuvių Lithuanian lt Luganda Ganda lug Latviešu Latvian lv 中文 (文言文) Chinese (Literary) lzh मैथिली Maithili mai Malagasy Malagasy mg Te Reo Māori Māori mi Македонски Macedonian mk മലയാളം Malayalam ml Монгол хэл Mongolian (Cyrillic) mn-Cyrl ᠮᠣᠩᠭᠣᠯ ᠬᠡᠯᠡ Mongolian (Traditional) mn-Mong মৈতৈলোন Manipuri mni मराठी Marathi mr Melayu Malay ms Malti Maltese mt Hmong Daw Hmong Daw mww မြန်မာ Myanmar (Burmese) my Norsk Bokmål Norwegian Bokmål nb नेपाली Nepali ne Nederlands Dutch nl Sesotho sa Leboa Sesotho sa Leboa nso Chinyanja Chichewa nya ଓଡ଼ିଆ Odia or Hñähñu Querétaro Otomi otq ਪੰਜਾਬੀ Punjabi pa Polski Polish pl دری Dari prs پښتو Pashto ps Português (Brasil) Portuguese (Brazil) pt Português (Portugal) Portuguese (Portugal) pt-PT Română Romanian ro Русский Russian ru Ikirundi Rundi run Kinyarwanda Kinyarwanda rw سنڌي Sindhi sd සිංහල Sinhala si Slovenčina Slovak sk Slovenščina Slovenian sl Gagana Sāmoa Samoan sm chiShona Shona sn Soomaali Somali so Shqip Albanian sq Српски (ћирилица) Serbian (Cyrillic) sr-Cyrl Srpski (latinica) Serbian (Latin) sr-Latn Sesotho Sesotho st Svenska Swedish sv Kiswahili Swahili sw தமிழ் Tamil ta తెలుగు Telugu te ไทย Thai th ትግር Tigrinya ti Türkmen Dili Turkmen tk Lea fakatonga Tongan to Türkçe Turkish tr Татар Tatar tt Reo Tahiti Tahitian ty ئۇيغۇرچە Uyghur ug Українська Ukrainian uk اردو Urdu ur Uzbek (Latin) Uzbek (Latin) uz Tiếng Việt Vietnamese vi isiXhosa isiXhosa xh Èdè Yorùbá Yoruba yo Yucatec Maya Yucatec Maya yua 粵語 Cantonese (Traditional) yue 中文 (简体) Chinese Simplified zh-Hans 中文 (繁體) Chinese Traditional zh-Hant isiZulu isiZulu zu

YAML

تكوين المستودع

يقوم Express بالإعدادات الافتراضية مرة واحدة في ملف إعدادات المستودع ويسمح لكل سير عمل بوراثتها. دائما ما تكون مدخلات الفعل تفوز عندما يتم توفير كلاهما.

في هذه الصفحة

    تجاوز المسار باستخدام مدخل configPath إذا كنت بحاجة إلى موقع غير افتراضي.

    المخطط

    .github/resource-translator.yml
    # .github/resource-translator.yml
    sourceLocale: en
    toLocales:
    - fr
    - de
    - es
    include:
    - "src/**/*.en.json"
    - "apps/**/*.en.resx"
    exclude:
    - "**/__tests__/**"
    glossary:
    Acme: Contoso
    Octocat: Octocat # keep brand names verbatim
    # Domain / industry — uses an Azure Custom Translator category trained on
    # your tone and vocabulary. Leave unset for the general model.
    categoryId: my-custom-translator-category
    # Translator request shape — most users can ignore these.
    textType: plain # plain | html
    profanityAction: NoAction # NoAction | Marked | Deleted
    profanityMarker: Asterisk # Asterisk | Tag (only when profanityAction == Marked)
    allowFallback: true # false fails when the categoryId has no deployment
    apiVersion: "3.0"
    # Resilience — Translator returns 429 under load. Defaults are usually
    # fine; tune only if your runs are large enough to hit them.
    maxRetries: 5
    retryBackoffMs: 30000 # cap on any single backoff sleep (ms)
    # Placeholder protection. ON by default — wraps tokens like {{name}},
    # {0}, %s, ${var} into sentinels before translation and restores them
    # on the way back. Set false only when source intentionally contains
    # placeholder-shaped literals.
    protectPlaceholders: true
    customPlaceholderPatterns:
    - "<<.+?>>" # any extra token syntax you use
    # Per-key opt-out. Keys matching any glob are dropped from the request
    # and pass through with the source value preserved.
    noTranslatePatterns:
    - "errors.code.*"
    - "brands.*"

    مرجع الحقل

    مرجع حقل التكوين
    الميدان النوع ملاحظات
    sourceLocale string يعود إلى مدخل sourceLocale إذا لم يكن مضبوطا. وأيضا تم تحويلها إلى المترجم from=<locale> حتى لا يتم اكتشاف السلاسل القصيرة تلقائيا.
    toLocales string[] إما مصفوفة أو سلسلة مفصولة بفاصل.
    include / exclude string[] يتم تقييم أنماط الكروب مقابل المسارات المطلقة والمسارات النسبية لمساحة العمل.
    glossary map<string,string> تجاوز المصطلحات بعد الترجمة. واعية بحدود الكلمة (تتعامل مع C++، .NET).
    categoryId string Azure Custom Translator فئة — مقبض الصناعة/المجال (القانوني، الطبي، التسويق، إلخ). تم إرسالها ?category=....
    textType "plain" | "html" الافتراضي على plain. استخدم html فقط إذا كانت قيم الموارد تحتوي على شظايا HTML حقيقية.
    profanityAction "NoAction" | "Marked" | "Deleted" كيفية التعامل مع المصطلحات البذيئة في المخرجات المترجمة.
    profanityMarker "Asterisk" | "Tag" لا معنى له إلا عندما يكون profanityAction "Marked".
    allowFallback boolean قم بتعيين false لفشل الترجمة عندما لا يكون لدى categoryId نشر لموقع هدف بدلا من العودة إلى النموذج العام.
    apiVersion string نسخة API المترجمة REST. الافتراضي على 3.0.
    maxRetries integer أقصى محاولات إعادة المحاولة على ردود HTTP المؤقتة (408, 425, 429, 500, 502, 503, 504). الافتراضية 5. إجمالي استدعاءات HTTP لكل طلب هو 1 + maxRetries.
    retryBackoffMs integer الحد الأقصى (ms) في أي نوم ارتكاف واحد. الافتراضي على 30000. رأس Retry-After لأزور يحترم بالضبط عند وجوده؛ وإلا يستخدم ارتداد أسي متقطع، مع حد أقصى لهذه القيمة.
    protectPlaceholders boolean الافتراضي على true. عند تشغيلها، يتم استبدال رموز مثل {{name}} و ${var} و {0} و {0:N2} و %s و %1$s وHTML برموز سنتينل قبل الترجمة وتستعاد بعد ذلك. قم بتعطيله فقط عندما يحتوي المصدر عمدا على حروف مؤقتة.
    customPlaceholderPatterns string[] تمت إضافة أنماط regex إضافية (بدون فاصلات) إلى مجموعة الرموز المؤقتة الافتراضية، مثل <<.+?>> لصياغة الرموز المخصصة. يتم تجاهل القواعد غير الصالحة.
    noTranslatePatterns string[] أنماط الغلوب تطابق مع مفاتيح على مستوى المحلل (مسار JSON المنقط، name RESX، msgid PO، وحدة XLIFF id، مفتاح INI/restext). يتم حذف المفاتيح المطابقة من الطلب وتمريرها مع الحفاظ على قيمة المصدر.

    ترتيب التحميل

    1. يقرأ الإجراء مدخلات صريحة من سير العمل.
    2. يقوم بتحميل إعدادات YAML من configPath.
    3. لكل حقل مشترك، يفوز المدخل؛ وإلا يتم استخدام قيمة YAML.
    4. يتم التحقق من صحة القيم المدمجة. العدد غير الصحيح (مثل profanityAction: Mask) يسبب فشل الفعل بسرعة مع وجود رسالة واضحة.

    النبرة والصناعة، بعبارات بسيطة

    واجهة برمجة تطبيقات Azure AI Translator v3 لا تحتوي على مقبض نغمة واحد. يجمع إعدادان ليمنحوك معظم عناصر التحكم نفسها:

    • الصناعة / المجال: استخدم categoryId للإشارة إلى فئة Azure Custom Translator المدربة على مجموعتك الخاصة — سواء القانونية أو التقنية أو الطبية أو التسويق أو أي شيء آخر. هذه هي أقوى رافعة للنبرة، وصوت العلامة التجارية، والمفردات.
    • نص سطحي: استخدم القاموس لتحديد أسماء العلامات التجارية ومصطلحات المنتجات حرفيا، واستخدم profanityAction لإزالة المصطلحات النابية عند استهداف التوطين للجمهور الأصغر سنا.