質問編集履歴

1

書式の改善

2020/11/28 19:42

投稿

katakata12
katakata12

スコア2

test CHANGED
File without changes
test CHANGED
@@ -1,8 +1,12 @@
1
- 以下のような文字列が記載されたテキストファイルがあります.![![イメージ説明](5e563b4003aedbf2f8b4c8a903d2dcab.png)](deeb1a9d50abea33008ea7263a974079.png)
1
+ Pythonでテキストファイルから指定の範囲内の文字列だけを抽出し表示するプログラムを作っています.
2
2
 
3
3
 
4
4
 
5
+ 実現したいこと
6
+
7
+ ![イメージ説明](c3e82dc9cbad68d3613f4f489d988f4a.png)
8
+
5
- のファイルから指定範囲内の文字列だけを抽出し表示する方法を教えていただきたいです.例えば各行の8列目から17列目までの数字列を抽出し
9
+ 上図テキストファイルの各行の8列目から17列目までの数字列を抽出し
6
10
 
7
11
  549129236
8
12
 
@@ -10,6 +14,46 @@
10
14
 
11
15
    :
12
16
 
17
+ と表示させたいと考えています.
18
+
19
+ 下記のプログラムを実行しても何も表示されませんでした.原因が分かる方がいましたらご教授いただけないでしょうか.
13
20
 
14
21
 
22
+
23
+ ```Python3.7
24
+
25
+ import re
26
+
27
+ filepath = 'file.txt'
28
+
29
+ pattern_prev = "{'ts': "
30
+
31
+ pattern_next = ", 's'"
32
+
33
+
34
+
35
+ def extract_text_in_file(filepath, pattern_prev, pattern_next):
36
+
15
- と表示させるのにはどうすればよいのでしょうか?
37
+ extracted_text_array = []
38
+
39
+ pattern = pattern_prev + '(.*)' + pattern_next
40
+
41
+ with open(filepath) as f:
42
+
43
+ lines = f.readlines()
44
+
45
+ for line in lines:
46
+
47
+ tmp_extracted_text_array = re.findall(pattern, line)
48
+
49
+ extracted_text_array.extend(tmp_extracted_text_array)
50
+
51
+
52
+
53
+ return extracted_text_array
54
+
55
+ print(extracted_text)
56
+
57
+
58
+
59
+ ```