Форум программистов, компьютерный форум, киберфорум
Наши страницы

Python

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

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

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

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

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

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

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

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

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

Чтение из файла - Python
Пишу я значит программу по генерированию дорок. Считываю из файла с ссылками параметр "name of page". При выполнении Visual Studio выдаёт...

Чтение из файла - Python
Имеется некий файл, в котором построчно записана некая информация. Эту информацию я считываю построчно методом readline(). Но вот как...

Чтение из файла - Python
Есть такое вот задание: Create a text file that contains names (e.g. “Joe Abernathy”) and salaries. Write a program that: Prompts...

Чтение из txt файла - Python
Имеется txt файл. В нем написан текст, а между текстами знаки "=========". То есть нужно читать текст между знаками "===", а затем сделать...

27
bestol
95 / 1 / 1
Регистрация: 01.08.2011
Сообщений: 35
09.08.2011, 19:12 #16
Nameless One,

Создатель Питона (Гвидо Ван Россум) рекомендует так оформлять запускаемый модуль:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import sys
import getopt
 
class Usage(Exception):
    def __init__(self, msg):
        self.msg = msg
 
def main(argv=None):
    if argv is None:
        argv = sys.argv
    try:
        try:
            opts, args = getopt.getopt(argv[1:], "h", ["help"])
        except getopt.error, msg:
             raise Usage(msg)
        # more code, unchanged
    except Usage, err:
        print >>sys.stderr, err.msg
        print >>sys.stderr, "for help use --help"
        return 2
 
if __name__ == "__main__":
    sys.exit(main())
Тут появляется возможность вводить аргументы прямо из IDLE (среды написания кода) как аргументы main. В этом случае не будет выскакивать противное сообщение о закрытии окна IDLE (которое появляется при вызове exit()). Там он еще учел, что argv могут измениться с момента запуска программы, поэтому он в функцию main значением по-умолчанию запихнул None (если указать вместо None sys.argv, то это значение по-умолчанию вычисляются только в момент создания функции, и потом остаются там на все время выполнения программы). Т.е. здесь при вызове main() без аргументов аргументы возьмутся из текущих значений sys.argv. А при передаче main() аргументов будут использованы они.

Более подробно можно у него в блоге почитать. Находится по "Guido Van Rossum main()" в Гугле.
0
Nameless One
Эксперт С++
5777 / 3427 / 255
Регистрация: 08.02.2010
Сообщений: 7,448
10.08.2011, 03:53 #17

Не по теме:

Цитата Сообщение от bestol Посмотреть сообщение
Тут появляется возможность вводить аргументы прямо из IDLE ...
Я пишу в Emacs'е


И да, для таких вещей, мне кажется, все же лучше использовать модули типа argparse и optparse, они сами usage генерируют . Ну тут, видимо, просто такой пример был.
А возможность вводить аргументы в главную функцию при отладке выглядит интересно, да.
0
v panike =(
1 / 1 / 0
Регистрация: 08.08.2011
Сообщений: 10
10.08.2011, 15:49  [ТС] #18
tak, u ma ni odna iz etix programm ne begaet... ne znayu....

a samoe ujasnoe, mne ved nado chitat v fayla,,, chto delat s etim?
0
Nameless One
Эксперт С++
5777 / 3427 / 255
Регистрация: 08.02.2010
Сообщений: 7,448
10.08.2011, 17:19 #19
Цитата Сообщение от v panike =( Посмотреть сообщение
tak, u ma ni odna iz etix programm ne begaet...
сейчас я проконсультируюсь у своего знакомого экстрасенса, и он мне расскажет подробнее, в чем состоит суть твоей проблемы... Начиная с самого начала: какая у тебя операционка, какой у тебя питон, в чем именно проявляется ошибка и т.д. и т.п.
0
v panike =(
1 / 1 / 0
Регистрация: 08.08.2011
Сообщений: 10
10.08.2011, 19:03  [ТС] #20
znachit tak, ya s etim begom razobralas...


seychas vopros: ya ne xochu chitat s csv, u mena .txt fayl!

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
data_file = open("patientdata.txt", "r")
 
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(",")
     h1, h2, h3,   =  string (h1), string (h2), string (h3)
     h4, h5, h6,   =  string (h4), string (h5), string (h6)
     h7, h8, h9 = string (h7), string (h8), string (h9)
     h10, h11,h12 = string (h10), string (h11), string (h12)
     h13,h14,h15 = string (h13), string (h14), string (h15)
     cnt = int(cnt)
vse chto ya smogla sdelat... kak vidite ne gusto...

mne teper nujno: chtob bil cikl: kotoriy bi schital kolichestvo s 1 do cnt...
i prisvaival znachenie stroki.

to est, kak v tom moem primere exam(1) = ..
exam(2) =
0
accept
4828 / 3249 / 165
Регистрация: 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
Эксперт С++
5777 / 3427 / 255
Регистрация: 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 / 0
Регистрация: 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
Привет! Вот еще темы с ответами:

Чтение из файла и 3D график - Python
f=open('primer2.dat','rb') def funk(): data=f.readline() while data: print(data) data=f.readline() ...

Чтение из файла csv - Python
Здравствуйте! Читаю из файла csv данные, представленные в виде Поле1 Поле2 Поле3 Поле1 Поле2 Поле3 ... ... ...

Чтение и парсинг файла - Python
Пару часов назад начал учить питон. Дело такое: есть файл, в нем есть строка &lt;title&gt;Текст&lt;/title&gt;...как вытащить слово &quot;Текст&quot;? f =...

Чтение html файла - Python
помогите пожалуйста с программой на питоне, которая читает файл html и выводит след информацию на экран: название html-ки из тэга title,...


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

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

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