تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[VB.NET] كيفية حفظ عناصر DataGridView الى ملف نصى text file
#1
السلام عليكم

اريد كيفية حفظ عناصر DataGridView الى ملف نصى text file


صورة من الاداة



اريد حفظ الارقام الموجودة فى عمود IP

ولكن بشروط معينة

اولا

يتم التحقق من هذه الارقام

5.189.201.0 - 5.189.201.127
5.254.105.152 - 5.254.105.159
23.236.140.0 - 23.236.140.255
31.14.248.0 - 31.14.248.255

واريد انا احفظ الارقام المحصورة بينهم

مثال

من 5.189.201.127
الى 5.189.201.0
ومن 5.254.105.159
الى 5.254.105.152
وهكذا

انا فكرت ان استخرج الاكواد المحصورة بين الارقام

واتحقق منها ولكن لقيت ان البرنامج هيعلق وهيستخدم وقت كثير للحفظ

لان الاداة سوف يكون فيها عناصر من 100الف الى 500 الف تقريبا

فلذلك كتبت موضوعى هنا
لكى تساعدونى بطريقة تكون اسهل واسرع

بانتظاركم يا شباب ومشكورين مقدما
الرد }}}
تم الشكر بواسطة:
#2
طلبك ليس صعبا لكنه يحتاج الي وقت

اولا بما انه ليس هناك صورة توضح البيانات في الداتاجريدفيو
هنا مهم جدا أن نعرف كم عدد الأعمدة في الداتاجريد فيو لأن هذا سوف يحدد  اي الاعمدة سوف نستخدم لتحويل بياناته الي مصفوفة

عموما الفكرة هنا عبارة عن استخدام DataSource الخاصة ب الداتاجريد فيو و تحويلها الي مصفوفة عناصر  أو الي DataTable مثلا
ثم تستخدم Serialization و De-Serialization لحفظ العناصر في ملف او لإسترجاع العناصر من الملف
أما نوع الملف فقد يكون xmal او تكست أو اي ملف

و المقصود بعملية  Serialization و De-Serializatio
انك تستخدم FileStream مع BinaryFormatter لحفظ او استرجاع عناصر  المصفوفة من الملف

و الكود الخاص بهذا سيكون شيئا من هذا القبيل و هو الحل لمشكلتك
وعليك فقط ان تستخدم كلمة IP بدلا من كلمة Object
والكود مكتوب ب اسلوب ان الحفظ يتم في ملف تحدد انت الاسم الخاص به و تحدد امتداده أيضا

PHP كود :
   Public Sub Serialize(fileName As String, list As IEnumerable(Of Object))

 
       Dim fs As System.IO.FileStream = New System.IO.FileStream(fileNameSystem.IO.FileMode.OpenOrCreate)
 
       Dim formatter As System.Runtime.Serialization.Formatters.Binary.BinaryFormatter = New System.Runtime.Serialization.Formatters.Binary.BinaryFormatter()
 
       Try
            formatter
.Serialize(fs, list)
 
           fs.Close()
 
       Catch ex As System.Runtime.Serialization.SerializationException
            MessageBox
.Show(ex.Message ": " ex.StackTrace"Error"MessageBoxButtons.OKMessageBoxIcon.Error)
 
       End Try

 
   End Sub

    Public 
Function Deserialize(fileName As String) As IEnumerable(Of Object)

 
       Dim fs As System.IO.FileStream = New System.IO.FileStream(fileNameSystem.IO.FileMode.Open)
 
       Dim list As New List(Of Object)()

 
       Try
            Dim Formatter 
As New System.Runtime.Serialization.Formatters.Binary.BinaryFormatter()
 
           list Formatter.Deserialize(fs)
 
           fs.Close()
 
           Return list
 
       Catch ex As System.Runtime.Serialization.SerializationException
            MessageBox
.Show(ex.StackTraceex.MessageMessageBoxButtons.OKMessageBoxIcon.Error)
 
           Return list
 
       End Try

 
   End Function 


نصيحتي لك أن تبني كلاس يكون اساسه العناصر  التي سوف يتم حفظها خاصة اذا كان لديك اكثر من عنصر غير IP سوف يتم حفظه في الملف

ثم تبني Collection لهذا الكلاس حتي تستطيع ان تتحكم بعناصر المصفوفة بشكل أفضل أثناء عملية ظهورها في الداتاجريد فيو او أثناء حفظها في الملف

حل أخر

وهذا الحل مناسب جدا خاصة ان كانت البيانات المراد تخزينها بيانات غير حساسة
انك تستخدم XmlTextReader , لقراءة البيانات وتستخدم XmlTextWriter لحفظ البيانات

حل أخر

انك تستخدم BinaryReader مع BinaryWriter


عموما الأمر محتاج مجهود منك لتخزين البيانات بشكل دقيق حسب اهمية و نوعية البيانات
الرد }}}
تم الشكر بواسطة: HASAN6.0 , khodor1985 , khodor1985
#3
اسف لانى لم اضع صورة

السلام عليكم

اريد كيفية حفظ عناصر DataGridView الى ملف نصى text file


صورة من الاداة



اريد حفظ الارقام الموجودة فى عمود IP

ان اريد ان اعدل طلبي حتى يسهل على عمله وفهمه

اريد الحفظ عن طريق اسم البلد

كل بلد يتم حفظ الايبهات بتاعتها فى ملف نصى لوحدها

مثلا
Egypt.txt
Angola.txt
وهكذا

اعتقد هذا هو الحل الاسهل والافضل

لان القايمة هتكون فوق 500الف ايبى

ولو حفظت عن طريق الايبهات

يبقا هحتاج شهر عشان اكتر كل الايبهات فى الكود

واسبوع عشان يحفظ قائمة واحدة

هذا خطى بعتذر عن ذلك

المطلوب

اريد الحفظ عن طريق اسم البلد

كل بلد يتم حفظ الايبهات بتاعتها فى ملف نصى لوحدها

مثلا
Egypt.txt
Angola.txt
وهكذا

الفكرة لم لم يفهم جيدا

لدى 3 عواميد

العمود الاول فيه الايبى
العمود الثانى فيه اسم البلد
العمود الثالث فيه علم البلد

المفروض نعمل كود يحفظ ايبهات مصر فى ملف نصى لوحدها
وايبهات انجولا فى ملف لوحدها وهكذا

واسف على الاطالة

بانتظار المساعدة

ومشكورين مقدما
الرد }}}
تم الشكر بواسطة:
#4
هل من حل او مساعد يا شباب
انا محتاج مساعدة فى اقرب وقت ان امكن
ومشكورين مقدما

لكل من حاول المساعدة -
الرد }}}
تم الشكر بواسطة:
#5
اخى الغالى

شكرا لك معلش تعبتك معى

ولكنى لا استعمل قواعد البيانات

عموما انا لقيت حل فى موقع اخر

والحمدلله افاد بالغرض

هذا هو الكود

Dim y As Integer = 0
Dim strFile As String
Dim sw1 As StreamWriter
Do Until y = DataGridView1.RowCount - 1
Dim x As String = DataGridView1.Rows(y).Cells(1).Value
strFile = x & ".txt"
If (Not File.Exists(strFile)) Then
sw1 = File.CreateText(strFile)
sw1.WriteLine(DataGridView1.Rows(y).Cells(0).Value)
sw1.Close()
Else
sw1 = (File.AppendText(strFile))
sw1.WriteLine(DataGridView1.Rows(y).Cells(0).Value)
sw1.Close()
End If
y = y + 1
Loop


شكرا لكم جميعا

اتمنى اغلاق الموضوع للانتهاء
الرد }}}
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  كيفية منع ظهور الأخطاء من إعدادات البيسيك mmaalmesry 2 852 29-08-25, 10:30 AM
آخر رد: mmaalmesry
  كيفية جلب أسماء الأعمدة بجدول من جداول sql heem1986 2 748 17-08-25, 09:15 PM
آخر رد: heem1986
  كيفية حفظ إعدادات البرنامج بحيث لا تتغير أحمد إبراهيم سعد 4 3,004 06-08-25, 06:34 PM
آخر رد: Taha Okla
  مساعدة في كيفية ترحيل البيانات من داتا قريدفيو إلى داتا قريدفيو في فيجوال بيسك ahmedfa71 13 2,248 09-07-25, 11:24 PM
آخر رد: أبو خالد الشكري
  [VB.NET] محتاج اربط DataGridView بزر بحث bakrycold 1 556 28-02-25, 12:11 AM
آخر رد: bakrycold
  كيفية احتساب الفرق بين تاريخين بناء على عدد معين مصمم هاوي 2 554 15-01-25, 02:02 PM
آخر رد: مصمم هاوي
  كيفية التعامل مع inputbox في فيجوال ستوديو أسامة حسين 4 3,514 14-01-25, 02:04 AM
آخر رد: أبو خالد الشكري
  [VB.NET] استعراض بيانات في Datagridview واضافة جميع البيانات لجدول محدد sql skode 0 489 12-01-25, 12:50 AM
آخر رد: skode
Information [VB.NET] تنسيق أعمدة DataGridView أبو خالد الشكري 3 583 21-12-24, 02:40 PM
آخر رد: aljzazy
  كيفية معرفة الجهاز رئيسي ام فرعي المتألق9 1 400 13-11-24, 06:41 PM
آخر رد: justforit

التنقل السريع :


يقوم بقرائة الموضوع: