Форум программистов, компьютерный форум, киберфорум
Наши страницы
Python
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 127, средняя оценка - 4.92
v panike =(
1 / 1 / 0
Регистрация: 08.08.2011
Сообщений: 10
#1

Построчное чтение данных из файла - Python

08.08.2011, 16:34. Просмотров 20515. Ответов 27
Метки нет (Все метки)

здравствуйте

нужна помощь!

поручили написать программу на питоне, которая будет считывать данные с файла, при этом по строкам!

никаких идей, вижу питона в 1 раз... так что в панике, жду помощи!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.08.2011, 16:34
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Построчное чтение данных из файла (Python):

Чтение данных из файла, который указан в командной строке
Здравствуйте. В учебнике Саммерфильда "Программирование на Python. Подробное...

Чтение из файла
Имеется некий файл, в котором построчно записана некая информация. Эту...

Чтение из файла
Есть такое вот задание: Create a text file that contains names (e.g. “Joe...

Чтение из файла
Народ, помогите, пожалуйста. Мне надо разобрать программку на питоне, которая...

Чтение из файла
Пишу я значит программу по генерированию дорок. Считываю из файла с ссылками...

Чтение из файла в список
имеется такой файл (1.txt) 1 21 2.21 маша !!№21 как считать данные из...

27
accept
4833 / 3254 / 454
Регистрация: 10.12.2008
Сообщений: 10,569
11.08.2011, 02:20 #21
Цитата Сообщение от v panike =(
Python
1
h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15,cnt=line.split(",")
используй список
фактически нужно дать имя списку line.split(',')

Python
1
lst = line.split(',')
0
Nameless One
Эксперт С++
5785 / 3434 / 351
Регистрация: 08.02.2010
Сообщений: 7,448
11.08.2011, 04:02 #22
Цитата Сообщение от v panike =( Посмотреть сообщение
ya ne xochu chitat s csv, u mena .txt fayl!
... в котором хранятся данные, разделенные запятыми. Расширение роли не играет, csv - это тоже plain text файл.

Цитата Сообщение от v panike =( Посмотреть сообщение
mne teper nujno: chtob bil cikl: kotoriy bi schital kolichestvo s 1 do cnt...
i prisvaival znachenie stroki.
Python
1
2
for _ in range(cnt):
    # тело цикла
0
v panike =(
1 / 1 / 0
Регистрация: 08.08.2011
Сообщений: 10
11.08.2011, 16:10  [ТС] #23
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
data_file = open("patientdata.txt", "r")
f = data_file
for line in data_file:
   
     line = line.strip()
     if not line: continue
     f.readlines ()
     h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15,cnt=line.split(",")
     cnt = int(cnt)
     print cnt
         for i in range(cnt)
                  lineobs = line.strip()
                  if not lineobs : continue
                     f.readline ()
                     print lineobs
      f.close()
      end()
znachit tak, proga rabotaet, no na novuyu stroku ne perekluchaetsa! ona mne cnt kolichestvo raz pervuyu stroku daet!!
please, nujna pomoj!!! oooochen srochno!
0
bestol
95 / 1 / 1
Регистрация: 01.08.2011
Сообщений: 35
11.08.2011, 17:53 #24
Код нужно вставлять сюда на форум в специальном теге.
Иначе все получается в стоблик, а в Питоне так работать не будет.

Ваш код вначале открывает data_file.
Потом вы идете по строчкам (for line in data_file)
line - это строчка.

Потом вы читаете все оставшиеся строки из файла (f.readlines ()) в середине цикла. Зачем?

Python
1
h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15,cnt=line.split(",")
Это вас просили убрать и сделать массив.

Python
1
2
3
4
5
6
7
for i in range(cnt)
 lineobs = line.strip()
 if not lineobs : continue
 f.readline ()
 print lineobs
 f.close()
 end()
Что это у вас делает? Нишите по строчкам, что конкретно каждая строчка делает.
0
v panike =(
1 / 1 / 0
Регистрация: 08.08.2011
Сообщений: 10
11.08.2011, 18:38  [ТС] #25
h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15,cnt=line.split(",") eto ved ne stroki!!! mne ved nujni eti elementi! eto vse emelenti odnoy stroki, razdelennie zapatoy... mne v programme obazatelno nujno obyavlat ix! chto eto bilo ima, vozrast i vse takoe!

a kak mne massiv strok zadat, to, chto vi ne napisali u ma uje v programe est je! on vse ravno chitaet odnu...
0
bestol
95 / 1 / 1
Регистрация: 01.08.2011
Сообщений: 35
11.08.2011, 21:53 #26
h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15,cnt=line.split(",")
А почему нельзя записать так:
Python
1
values = line.split(",")
и потом к ним обращаться:
Python
1
2
3
4
values[0]
values[1]
...
values[15]
0
v panike =(
1 / 1 / 0
Регистрация: 08.08.2011
Сообщений: 10
02.09.2011, 14:57  [ТС] #27
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
import MySQLdb
 
 
 
 
 
data_file = open("/home/dilara/Desktop/patientdata.txt", "r")
 
f = data_file
 
 
 
#for line in f.readlines():
 
 
 
for l in range(20):
 
     line=f.next()
 
     print l,"=====",line
 
 
 
     line = line.strip()
 
     if not line: continue
 
#     f.readlines ()
 
 
 
     h1,h2,h3,h4,h5,h6,h7,h8,h9,h10,h11,h12,h13,h14,h15,cnt = line.split(",")
 
 
 
     cnt = int(cnt)
 
 
 
     print 'name         ',h1
 
     print 'surname      ',h2
 
     print 'Gender       ',h3
 
     print 'DOB          ',h4
 
     print 'DIagnosis    ',h5
 
     print 'diagnosis code',h6
 
     print 'T_Stage      ',h7
 
     print 'mStage       ',h8
 
     print 'nStage       ',h9
 
     print 'Grade        ',h10
 
     print 'PS           ',h11
 
     print 'Dose         ',h12
 
     print 'Franction    ',h13
 
     print 'Begining Date',h14
 
     print 'End Date     ',h15
 
 
 
 
 
 
 
     j=80
 
     a = line.split(",")
 
     a.insert(0, str(j))
 
     b=[]
 
     b.insert(0, str(j))
 
     b.insert(1, h1)
 
     b.insert(2, h2)
 
     b.insert(3, h3)
 
     b.insert(4, h4)
 
     b.insert(5, h11)
 
     b.insert(6, h5)
 
     b.insert(7, h6)
 
     b.insert(8, h7)
 
     b.insert(9, h8)
 
     b.insert(10, h9)
 
     b.insert(11, h10)
 
     values = '\', \''.join(b)
 
  #   print a
 
   #  print values
 
     print values
 
     connect=("localhost","root","grid12345","testdb",3306)
 
     db = MySQLdb.connect(connect[0],connect[1],connect[2],connect[3],connect[4])
 
     cursor = db.cursor()
 
   #  SQL = """INSERT INTO patient_anonymous (ID_Patient,First_Name, Surname, Gender, 
 
    #   Date_of_Birth, Performance_Status, Diagnosis, Diagnosis_Code,
 
     #  T_Stage, N_Stage, M_Stage,Grade)
 
#   VALUES ('j', 'h1', 'h2', 'h3', 'h4', 'h6', 'h5', 'h7', 'h8', 'h9', 'h10', 'h11')"""
 
 
 
 
 
     SQL2 = """INSERT INTO patient (ID_Patient,First_Name, Surname, Gender, Date_of_Birth, Performance_Status, Diagnosis, Diagnosis_Code,
 
               T_Stage, N_Stage, M_Stage, Grade)
 
               VALUES (\'%s\')""" % values 
 
     print SQL2
 
     j=j+1
 
  #    aa = b[0]
 
  #    av = b[1]
 
   #   ac = b[2]
 
   #   ad = b[3]
 
#      af = b[4]
 
 #     ag = b[5]
 
  #    ah = b[6]
 
  #    aj = b[7]
 
  #    ak = b[8]
 
  #    al = b[9]
 
   #   aq = b[10]
 
   #   aw = b[11]
 
  #    SQL = """INSERT INTO patient_anonymous (ID_Patient,First_Name, Surname, Gender,
 
   #    Date_of_Birth, Performance_Status, Diagnosis, Diagnosis_Code,
 
    #   T_Stage, N_Stage, M_Stage,Grade) VALUES ('aa','av','ac','ad','af','ag','ah','aj','ak','al','aq','aw')"""
 
 
 
     cursor.execute(SQL2)
 
     results = cursor.fetchall()
 
  #    j=j+1
 
     #     line = line + '\n'
 
     listofobs = []
 
     l=0
 
     k=0
 
     dataobs = []
 
 
 
     for i in range(cnt):
 
#     while i <= cnt:
 
        obsline = f.next()
 
        obsline=obsline.strip()
 
        if not obsline: continue
 
        listofobs.append(obsline)
 
        print "   OBS",i,"==",listofobs[l]
 
#        print "this is the list of observations", listofobs
 
#       print "this is observations one by one",l, listofobs[l]
 
 #       temp = listofobs[l]
 
#       dataobs = temp.split(",")
 
        dataobs=listofobs[l].split(",")
 
        print dataobs[0]
 
        danniedlaobs=[] #this is array of what we need for observation table
 
        forsideeffecttable=[] # this is array of what we need in sideeffects table
 
        doctab=[] # this is array for doctor table
 
        id_side=0
 
        id_doc=0
 
        for elem in dataobs:
 
                print elem
 
        danniedlaobs.insert(0,str(i))
 
        danniedlaobs.insert(1,str(1))
 
        danniedlaobs.insert(2,dataobs[0])
 
        danniedlaobs.insert(3,str(j))
 
        danniedlaobs.insert(4,str(k))
 
        print danniedlaobs
 
 
 
        forsideeffecttable.insert(0, str(id_side))
 
        forsideeffecttable.insert(1,dataobs[5])
 
        forsideeffecttable.insert(2,' ')
 
        forsideeffecttable.insert(3,dataobs[6])
 
        forsideeffecttable.insert(4,'CTCAE')
 
        forsideeffecttable.insert(5,' ')
 
        forsideeffecttable.insert(6,str(i))
 
 
 
        print forsideeffecttable
 
        doctab.insert(0,str(id_doc))
 
        doctab.insert(1,dataobs[2])
 
        doctab.insert(2,'name')
 
        doctab.insert(3,'  ')
        doctab.insert(4, '  ')
 
        
 
        values2 = '\', \''.join(danniedlaobs)
 
        values3 = '\', \''.join(forsideeffecttable)
 
        values4 = '\', \''.join(doctab)
 
        
 
        db = MySQLdb.connect(connect[0],connect[1],connect[2],connect[3],connect[4])
 
        cursor = db.cursor()
     SQL4 = """INSERT INTO patient (ID_Doctor, Surname, First_Name,  Institution, Specialization)
 
               VALUES (\'%s\')""" % values4 
 
 
 
        SQL = """INSERT INTO observation (ID_Observation, Observer,       
                 Date_Recorded, ID_Patient, DOCTOR_ID_Doctor) 
 
                   VALUES (\'%s\')""" % values2
 
        SQL3= """INSERT INTO sideeffect (ID_Sideeffect, Sideeffect, Code, Score, Scoring_System, Date_occurred, ID_Observation)
 
                 VALUES (\'%s\')""" % values3
 
       
 
        print SQL
 
        print SQL3
 
        print SQL4
 
 
 
    cursor.execute(SQL4)
 
        cursor.execute(SQL)
 
        cursor.execute(SQL3)
 
       
 
        results = cursor.fetchall()
 
        print dataobs, "===", "this is splited observations"
 
        k=k+1
 
        id_side = id_side+1
 
        l=l+1
 
        id_doc= id_doc+1
 
        db.commit()
 
 
 
f.close()
 
db.commit()
 
db.close()

pochemu on mne daet, chto u ma syntaxes error v SQL4!
net tak ved owibki ili ya ne viju! i voobje, pochemu eta proga ne rabotaet!? est otweti!?

p.s. ne ochen slojnaya sxema MySQL db, tam tolko pola s ID povtorayutsa i svazani, no vi i sami eto mojete po kodu i statementam zametit

Добавлено через 1 минуту
eje bilo b idealno, esli smogli b pomoch sdelat programmu, kotoraya prosto udalaet vse probeli po zapatoy i posle,
i schitaet kolichestvo strok v fayle...

Добавлено через 12 минут
eje,,,, mena strawno besit, chto esli sdelat SQL, SQL3, SQL4 commentom, to on mne prosto krasivo vipolnaet i vivodit na ekran, chto ya xochu, no SQL2 ne vipolnaet, DB- pustaya! chto ya delayu ne tak!?
0
Xorazm
0 / 0 / 1
Регистрация: 19.06.2017
Сообщений: 32
26.06.2017, 12:01 #28
Python
1
2
3
4
my_file = open("r.txt","r")
my_string = my_file.read()
print(my_string)
my_file.close()
читает на андроид!
0
26.06.2017, 12:01
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.06.2017, 12:01
Привет! Вот еще темы с решениями:

Чтение чисел из файла
Вот мой код digits = self.cell_list =...

Чтение из файла с числами
Есть файл вида 1 5 10 15 20 25 Необходимо прочитать файл так, чтобы на...

Чтение огромного файла
Требуется прочитать текстовый файл построчно с размером 800 мб (будет...

Чтение html файла
помогите пожалуйста с программой на питоне, которая читает файл html и выводит...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
28
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru