الفرق بين المراجعتين لصفحة: «Ruby/ARGF/read»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع <code>ARGF.read</code> في روبي}}</noinclude> تصنيف: Ruby تصنيف: Ruby Method تصنيف: Ruby ARGF...' |
لا ملخص تعديل |
||
سطر 3: | سطر 3: | ||
[[تصنيف: Ruby Method]] | [[تصنيف: Ruby Method]] | ||
[[تصنيف: Ruby ARGF]] | [[تصنيف: Ruby ARGF]] | ||
يقرأ التابع <code>read</code> عددًا محددًا من البايتات من المجرى | يقرأ التابع <code>read</code> عددًا محددًا من البايتات من المجرى <code>ARGF</code>. | ||
==البنية العامة== | ==البنية العامة== | ||
<syntaxhighlight lang="ruby"> read([length [, outbuf]]) → string, outbuf, or nil | <syntaxhighlight lang="ruby"> read([length [, outbuf]]) → string, outbuf, or nil </syntaxhighlight>يعالج هذا التابع جميع الملفات الممرَّرة في سطر الأوامر وكأنَّها ملفٌ واحدٌ، لذلك يعيد جميع محتويات هذا الملف الزائف (pseudo file) عند استدعائه دون تمرير أي وسائط. | ||
يعالج هذا التابع جميع الملفات الممرَّرة في سطر الأوامر وكأنَّها ملفٌ واحدٌ، لذلك يعيد جميع محتويات هذا الملف الزائف (pseudo file) عند استدعائه دون تمرير أي وسائط. | |||
إذا كانت قيمة الوسيط length عددًا صحيحًا موجبًا، فسيحاول التابع read قراءة | إذا كانت قيمة الوسيط <code>length</code> عددًا صحيحًا موجبًا، فسيحاول التابع <code>read</code> قراءة عددٍ من البايتات يساوي <code>length</code> دون إجراء أي تحويل (الوضع الثنائي [binary mode]). في حال كان <code>length</code> عددًا صحيحًا (integer)، تكون السلسلة النصية الناتجة مكتوبة بالترميز <code>ASCII-8BIT</code> دائمًا. | ||
لاحظ أنَّ التابع read يسلك نفس سلوك الدالة fread() في لغة C. هذا يعني أنَّ التابع يحاول تنفيذ استدعاءات النظام للدالة read(2) لقراءة البيانات وفق الطول المحدد. إذا كنت تريد أن تسلك هذه الدالة سلوك استدعاءٍ وحيدٍ للدالة read(2)، فيمكنك استخدام التابع | |||
لاحظ أنَّ التابع <code>read</code> يسلك نفس سلوك الدالة <code>fread()</code> في لغة C. هذا يعني أنَّ التابع يحاول تنفيذ استدعاءات النظام للدالة <code>read(2)</code> لقراءة البيانات وفق الطول المحدد. إذا كنت تريد أن تسلك هذه الدالة سلوك استدعاءٍ وحيدٍ للدالة <code>read(2)</code>، فيمكنك استخدام التابع <code>[[Ruby/ARGF/readpartial|readpartial]]</code> أو التابع <code>[[Ruby/ARGF/read nonblock|read_nonblock]]</code>. | |||
==المعاملات== | ==المعاملات== | ||
<code>length</code> | |||
عددٌ صحيحٌ موجب يحدد عدد البايتات المراد قراءتها. إن أعطيت القيمة <code>nil</code> لهذا الوسيط، فستستمر عملية القراءة من الملف حتى الوصول إلى محرف نهاية الملف | === <code>length</code> === | ||
<code>outbuf</code> | عددٌ صحيحٌ موجب يحدد عدد البايتات المراد قراءتها. إن أعطيت القيمة <code>nil</code> لهذا الوسيط، فستستمر عملية القراءة من الملف حتى الوصول إلى محرف نهاية الملف <code>(EOF)</code>. | ||
سلسلةٌ نصيةٌ تستعمل لتخزين البيانات المقروءة من المجرى | |||
ملاحظة: إن حوى هذا الوسيط أية بيانات سابقة قبل استدعاء الدالة <code>read</code>، فستكتب البيانات الجديدة التي تُقرَأ من المجرى فوق تلك البيانات القديمة. | === <code>outbuf</code> === | ||
سلسلةٌ نصيةٌ تستعمل لتخزين البيانات المقروءة من المجرى <code>ARGF</code>. | |||
'''ملاحظة''': إن حوى هذا الوسيط أية بيانات سابقة قبل استدعاء الدالة <code>read</code>، فستكتب البيانات الجديدة التي تُقرَأ من المجرى فوق تلك البيانات القديمة. | |||
==القيم المعادة== | ==القيم المعادة== | ||
تعاد سلسلة نصية تمثل البيانات التي قُرئت من المجرى | تعاد سلسلة نصية تمثل البيانات التي قُرئت من المجرى <code>ARGF</code>. | ||
تعاد القيمة <code>nil</code> عند الوصول إلى نهاية الملف (<code>EOF</code>) وقبل قراءة أي شيء منه. يعاد عددٌ من البايتات أقل مما هو محدد في الوسيط <code>length</code> عند الوصول إلى نهاية الملف (<code>EOF</code>) أثناء القراءة منه. | تعاد القيمة <code>nil</code> عند الوصول إلى نهاية الملف (<code>EOF</code>) وقبل قراءة أي شيء منه. يعاد عددٌ من البايتات أقل مما هو محدد في الوسيط <code>length</code> عند الوصول إلى نهاية الملف (<code>EOF</code>) أثناء القراءة منه. | ||
إن لم يعطَ الوسيط <code>length</code> أو كانت قيمته تساوي <code>nil</code>، فلن تتوقف عملية القراءة حتى يصل التابع إلى نهاية الملف (<code>EOF</code>) وستجرى عملية تحويل للترميز إذا كان ذلك ممكنًا. يمكن أن تعاد سلسلة نصية حتى لو صودفت نهاية الملف (<code>EOF</code>) قبل قراءة أية بيانات. | إن لم يعطَ الوسيط <code>length</code> أو كانت قيمته تساوي <code>nil</code>، فلن تتوقف عملية القراءة حتى يصل التابع إلى نهاية الملف (<code>EOF</code>) وستجرى عملية تحويل للترميز إذا كان ذلك ممكنًا. يمكن أن تعاد سلسلة نصية حتى لو صودفت نهاية الملف (<code>EOF</code>) قبل قراءة أية بيانات. | ||
إذا كان <code>length</code> يساوي | |||
إن أعطي الوسيط <code> | إذا كان <code>length</code> يساوي <code>0</code>، فسيعيد التابع سلسلة نصية فارغة (<code>""</code>). | ||
إن أعطي الوسيط <code>outbuf</code> الاختياري، فستُخزَّن البيانات التي تُقرَأ من المجرى <code>ARGF</code> في هذا الوسيط ثمَّ يعاد. | |||
==أمثلة== | ==أمثلة== | ||
مثالٌ على استخدام التابع <code>read</code>: | مثالٌ على استخدام التابع <code>read</code>: | ||
سطر 34: | سطر 41: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==انظر أيضًا== | ==انظر أيضًا== | ||
* التابع [[Ruby/ARGF/readbyte | <code>readbyte</code>]]: يقرأ البايت التالي من المجرى | * التابع [[Ruby/ARGF/readbyte | <code>readbyte</code>]]: يقرأ البايت التالي من المجرى <code>ARGF</code> ثمَّ يعيده على شكل عدد صحيح (<code>Integer</code>). | ||
* التابع [[Ruby/ARGF/read_nonblock | <code>read_nonblock</code>]]: يقرأ عددًا من البايتات لا يتجاوز قيمةً حديَّةً عليا من المجرى | * التابع [[Ruby/ARGF/read_nonblock | <code>read_nonblock</code>]]: يقرأ عددًا من البايتات لا يتجاوز قيمةً حديَّةً عليا من المجرى <code>ARGF</code> في وضع عدم الحجز (non-blocking mode). | ||
* التابع [[Ruby/ARGF/readchar | <code>readchar</code>]]: يقرأ المحرف التالي من المجرى | * التابع [[Ruby/ARGF/readchar | <code>readchar</code>]]: يقرأ المحرف التالي من المجرى <code>ARGF</code> ثم يعيده على شكل سلسلة نصية. | ||
* التابع [[Ruby/ARGF/readline | <code>readline</code>]]: يقرأ السطر التالي من الملف الحالي في المجرى | * التابع [[Ruby/ARGF/readline | <code>readline</code>]]: يقرأ السطر التالي من الملف الحالي في المجرى <code>ARGF</code>. | ||
* التابع [[Ruby/ARGF/readlines | <code>readlines</code>]]: يقرأ الملف الحالي في المجرى | * التابع [[Ruby/ARGF/readlines | <code>readlines</code>]]: يقرأ الملف الحالي في المجرى <code>ARGF</code> بشكل كامل. | ||
* التابع [[Ruby/ARGF/readpartial | <code>readpartial</code>]]: يقرأ عددًا من البايتات لا يتجاوز قيمةً حديةً عليا من المجرى | * التابع [[Ruby/ARGF/readpartial | <code>readpartial</code>]]: يقرأ عددًا من البايتات لا يتجاوز قيمةً حديةً عليا من المجرى <code>ARGF</code>. | ||
* * التابع [[Ruby/ARGF/gets | <code>gets</code>]]: يقرأ التابع [[Ruby/ARGF/gets | <code>gets</code>]] السطر الموالي في الملف الحالي في | * * التابع [[Ruby/ARGF/gets | <code>gets</code>]]: يقرأ التابع [[Ruby/ARGF/gets | <code>gets</code>]] السطر الموالي في الملف الحالي في <code>ARGF</code>. | ||
* التابع [[Ruby/ARGF/printf | <code>printf</code>]]: يطبع الكائن أو الكائنات الممرَّرة إليه على المجرى <code>ios</code> بعد تنسيقها بشكل معين. | * التابع [[Ruby/ARGF/printf | <code>printf</code>]]: يطبع الكائن أو الكائنات الممرَّرة إليه على المجرى <code>ios</code> بعد تنسيقها بشكل معين. | ||
* التابع [[Ruby/ARGF/to_a | <code>to_a</code>]]: يقرأ الملف الحالي في المجرى | * التابع [[Ruby/ARGF/to_a | <code>to_a</code>]]: يقرأ الملف الحالي في المجرى <code>ARGF</code> بشكل كامل ثم يضع محتوياته في مصفوفة. | ||
* التابع [[Ruby/ARGF/write | <code>write</code>]]: يكتب السلسلة النصية الممرَّرة إليها على المجرى | * التابع [[Ruby/ARGF/write | <code>write</code>]]: يكتب السلسلة النصية الممرَّرة إليها على المجرى <code>ARGF</code> في حال كان الوضع <code>inplace</code> مفعَّلًا. | ||
==مصادر== | ==مصادر== | ||
* قسم التابع read في الصنف ARGF في توثيق روبي الرسمي. | * [http://ruby-doc.org/core-2.5.1/ARGF.html#method-i-read قسم التابع read في الصنف ARGF في توثيق روبي الرسمي.] |
مراجعة 18:01، 10 سبتمبر 2018
يقرأ التابع read
عددًا محددًا من البايتات من المجرى ARGF
.
البنية العامة
read([length [, outbuf]]) → string, outbuf, or nil
يعالج هذا التابع جميع الملفات الممرَّرة في سطر الأوامر وكأنَّها ملفٌ واحدٌ، لذلك يعيد جميع محتويات هذا الملف الزائف (pseudo file) عند استدعائه دون تمرير أي وسائط.
إذا كانت قيمة الوسيط length
عددًا صحيحًا موجبًا، فسيحاول التابع read
قراءة عددٍ من البايتات يساوي length
دون إجراء أي تحويل (الوضع الثنائي [binary mode]). في حال كان length
عددًا صحيحًا (integer)، تكون السلسلة النصية الناتجة مكتوبة بالترميز ASCII-8BIT
دائمًا.
لاحظ أنَّ التابع read
يسلك نفس سلوك الدالة fread()
في لغة C. هذا يعني أنَّ التابع يحاول تنفيذ استدعاءات النظام للدالة read(2)
لقراءة البيانات وفق الطول المحدد. إذا كنت تريد أن تسلك هذه الدالة سلوك استدعاءٍ وحيدٍ للدالة read(2)
، فيمكنك استخدام التابع readpartial
أو التابع read_nonblock
.
المعاملات
length
عددٌ صحيحٌ موجب يحدد عدد البايتات المراد قراءتها. إن أعطيت القيمة nil
لهذا الوسيط، فستستمر عملية القراءة من الملف حتى الوصول إلى محرف نهاية الملف (EOF)
.
outbuf
سلسلةٌ نصيةٌ تستعمل لتخزين البيانات المقروءة من المجرى ARGF
.
ملاحظة: إن حوى هذا الوسيط أية بيانات سابقة قبل استدعاء الدالة read
، فستكتب البيانات الجديدة التي تُقرَأ من المجرى فوق تلك البيانات القديمة.
القيم المعادة
تعاد سلسلة نصية تمثل البيانات التي قُرئت من المجرى ARGF
.
تعاد القيمة nil
عند الوصول إلى نهاية الملف (EOF
) وقبل قراءة أي شيء منه. يعاد عددٌ من البايتات أقل مما هو محدد في الوسيط length
عند الوصول إلى نهاية الملف (EOF
) أثناء القراءة منه.
إن لم يعطَ الوسيط length
أو كانت قيمته تساوي nil
، فلن تتوقف عملية القراءة حتى يصل التابع إلى نهاية الملف (EOF
) وستجرى عملية تحويل للترميز إذا كان ذلك ممكنًا. يمكن أن تعاد سلسلة نصية حتى لو صودفت نهاية الملف (EOF
) قبل قراءة أية بيانات.
إذا كان length
يساوي 0
، فسيعيد التابع سلسلة نصية فارغة (""
).
إن أعطي الوسيط outbuf
الاختياري، فستُخزَّن البيانات التي تُقرَأ من المجرى ARGF
في هذا الوسيط ثمَّ يعاد.
أمثلة
مثالٌ على استخدام التابع read
:
$ echo "small" > small.txt
$ echo "large" > large.txt
$ ./glark.rb small.txt large.txt
ARGF.read #=> "small\nlarge"
ARGF.read(200) #=> "small\nlarge"
ARGF.read(2) #=> "sm"
ARGF.read(0) #=> ""
انظر أيضًا
- التابع
readbyte
: يقرأ البايت التالي من المجرىARGF
ثمَّ يعيده على شكل عدد صحيح (Integer
). - التابع
read_nonblock
: يقرأ عددًا من البايتات لا يتجاوز قيمةً حديَّةً عليا من المجرىARGF
في وضع عدم الحجز (non-blocking mode). - التابع
readchar
: يقرأ المحرف التالي من المجرىARGF
ثم يعيده على شكل سلسلة نصية. - التابع
readline
: يقرأ السطر التالي من الملف الحالي في المجرىARGF
. - التابع
readlines
: يقرأ الملف الحالي في المجرىARGF
بشكل كامل. - التابع
readpartial
: يقرأ عددًا من البايتات لا يتجاوز قيمةً حديةً عليا من المجرىARGF
. - * التابع
gets
: يقرأ التابعgets
السطر الموالي في الملف الحالي فيARGF
. - التابع
printf
: يطبع الكائن أو الكائنات الممرَّرة إليه على المجرىios
بعد تنسيقها بشكل معين. - التابع
to_a
: يقرأ الملف الحالي في المجرىARGF
بشكل كامل ثم يضع محتوياته في مصفوفة. - التابع
write
: يكتب السلسلة النصية الممرَّرة إليها على المجرىARGF
في حال كان الوضعinplace
مفعَّلًا.